2021年7月9日星期五

java mysql 数据库备份和还原操作

package com.itenp.gen.action;import java.io.BufferedReader;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.InputStream;import java.io.InputStreamReader;import java.io.OutputStreamWriter;import java.text.SimpleDateFormat;import java.util.Date;import java.util.HashMap;import java.util.List;import java.util.Map;import javax.annotation.Resource;import org.apache.log4j.Logger;import org.springframework.context.annotation.Scope;import org.springframework.stereotype.Controller;import com.itenp.gen.common.Constants;import com.itenp.gen.common.ParameterUtil;import com.itenp.gen.service.i.BackUpServiceI;import com.itenp.gen.system.PropertiesCache;import com.itenp.gen.vo.BackUpVO;import com.itenp.gen.vo.UserVO;/** 说明:数据备份还原 * 作者:fhadmin * from www.fhadmin.cn*/@SuppressWarnings("serial")@Scope("prototype")@Controller("backupAction")public class BackUpAction extends BaseAction {   private static Logger log = Logger.getLogger(BackUpAction.class);   private String databaseDirectory = PropertiesCache.getInstance().getDatabaseDirectory(); //数据库bin路径  private String databaseName = PropertiesCache.getInstance().getDatabaseName();//数据库名  private String userName = PropertiesCache.getInstance().getUserName();  private String userPwd = PropertiesCache.getInstance().getUserPwd();  private String copyDbCmd = PropertiesCache.getInstance().getCopyDbCmd();//数据库备份命令  private String copyprocCmd = PropertiesCache.getInstance().getCopyprocCmd();//存储工程备份命令  private String copyedFilePath = PropertiesCache.getInstance().getCopyedFilePath(); //备份后的文件存放位置  private String restoreCmd = PropertiesCache.getInstance().getRestoreCmd();  //数据库还原命令   private String msg = "";  private String msg1 = "";     private BackUpServiceI service;  @Resource(name="backupService") public void setBackupService(BackUpServiceI service){    this.service=service; }  @SuppressWarnings("unchecked") public String list() throws Exception {  //System.out.println("copyedFilePath"+copyedFilePath);  HashMap map = new HashMap();    //得到符合条件的记录List  List<BackUpVO> list = (List)service.findList(map);   request.setAttribute("list", list);  log.debug("####"+PropertiesCache.getInstance().getTemplateDirectory()); // System.out.println(PropertiesCache.getInstance().getTemplateDirectory());  return "success"; }  @SuppressWarnings("unchecked") public String backup() throws Exception {     Runtime rt = Runtime.getRuntime();        // 调用 mysql 的 cmd:                   /*System.out.println("数据库bin路径"+databaseDirectory);     System.out.println("数据库名"+databaseName);     System.out.println("用户名"+userName);     System.out.println("密码"+userPwd);     System.out.println("数据库备份命令"+copyDbCmd);     System.out.println("存储工程备份命令"+copyprocCmd);*/          String str = databaseDirectory+"/"+copyDbCmd+" --no-defaults "+"-u"+userName+" "+"-p"+userPwd+" "+copyprocCmd+" "+"--set-charset=utf-8"+" "+databaseName;          //str = "D:\SOFT\MySQL\MySQL Server 5.5\bin/mysqldump -uroot -proot -R --set-charset=utf-8 nlnk";          //System.out.println(str);          // Process child = rt.exec(databaseDirectory+"/"+copyDbCmd+" "+"-u"+userName+" "+"-p"+userPwd+" "+copyprocCmd+" "+"--set-charset=utf-8"+" "+databaseName);// 设置导出编码为utf8。这里必须是utf8     Process child = rt.exec(str);// 设置导出编码为utf8。这里必须是utf8           //调用mysql的cmd:备份某个表     // Process childtable = rt     // .exec("D:/db/mysql/mysql-5.0.45-win32/bin/mysqldump -uroot -pmysql --set-charset=utf8 ibtts t_a_dbbak");// 设置导出编码为utf8。这里必须是utf8     // Process childtable = rt     // .exec(databaseDirectory+"/"+copyDbCmd+" "+"-u"+userName+" "+"-p"+userPwd+" "+"--set-charset=utf8"+" "+databaseName+" "+"t_a_dbbak");// 设置导出编码为utf8。这里必须是utf8           // 把进程执行中的控制台输出信息写入.sql文件,即生成了备份文件。注:如果不对控制台信息进行读出,则会导致进程堵塞无法运行      InputStream in = child.getInputStream();// 控制台的输出信息作为输入流          InputStreamReader xx = new InputStreamReader(in, "utf8");// 设置输出流编码为utf8。这里必须是utf8,否则从流中读入的是乱码           String inStr;      StringBuffer sb = new StringBuffer("");      String outStr;      // 组合控制台输出信息字符串      BufferedReader br = new BufferedReader(xx);           // System.out.println("------------"+br.readLine());           while ((inStr = br.readLine()) != null) {       sb.append(inStr + "\r\n");      }      outStr = sb.toString();           //判断是否保存成功      if(outStr != null && !outStr.trim().equals("")){       msg="ok";      }                //System.out.println("-----"+outStr);       //创建文件名称      SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmss");      String today=format.format(new Date());           //String targetDirectory = scontext.getRealPath("/WEB-INF/DBbackup");       // System.out.println(targetDirectory);      // 要用来做导入用的sql目标文件:D:/ibtts.sql          FileOutputStream fout = new FileOutputStream(        copyedFilePath+"/"+today+"ibtts.sql" );      OutputStreamWriter writer = new OutputStreamWriter(fout, "utf8");      writer.write(outStr);     // 注:这里如果用缓冲方式写入文件的话,会导致中文乱码,用flush()方法则可以避免      writer.flush();        // 别忘记关闭输入输出流      in.close();      xx.close();      br.close();      writer.close();      fout.close();        // System.out.println("/* Output OK! */");      //数据添加到数据库      HashMap map = new HashMap();           map.put("db_nm", "ibtts");      map.put("bk_nm", today+"ibtts.sql");      map.put("bk_user",((UserVO)session.get(Constants.S_LOGIN_USER)).getUser_id());           service.create(map);          // copytable();           return list();    }  /**  * 数据的恢复  */ @SuppressWarnings("unchecked") public String load() throws Exception {    copytable();    //得到页面所有参数  Map<String, String> map = ParameterUtil.getStringMap(request,session);  //String targetDirectory = scontext.getRealPath("/WEB-INF/DBbackup");    //获取id后进行查询  BackUpVO vo=(BackUpVO) service.findById(map);    String fPath=copyedFilePath+"/"+vo.getBk_nm();    System.out.println(fPath);    //map.put("Id", vo.getId());  //String fPath = "D:/ibtts.sql";  Runtime rt = Runtime.getRuntime();  // 调用 mysql 的 cmd:  //Process child = rt.exec("D:/db/mysql/mysql-5.0.45-win32/bin/mysql -uroot -pmysql ibtts");  Process child = rt.exec(databaseDirectory+"/"+restoreCmd+" "+"-u"+userName+" "+"-p"+userPwd+" "+databaseName);    //System.out.println(databaseDirectory+"/"+restoreCmd+" "+"-u"+userName+" "+"-p"+userPwd+" "+databaseName);    java.io.OutputStream out =child.getOutputStream();//控制台的输入信息作为输出流  String inStr;  StringBuffer sb = new StringBuffer("");  String outStr;  BufferedReader br = new BufferedReader(new InputStreamReader(  new FileInputStream(fPath), "utf8"));  while ((inStr = br.readLine()) != null) {  sb.append(inStr + "\r\n");  }  outStr = sb.toString();  OutputStreamWriter writer = new OutputStreamWriter(out, "utf8");  writer.write(outStr);  // 注:这里如果用缓冲方式写入文件的话,会导致中文乱码,用flush()方法则可以避免  writer.flush();  // 别忘记关闭输入输出流  out.close();  br.close();  writer.close();    //获取还原用户  map.put("restore_user", ((UserVO)session.get(Constants.S_LOGIN_USER)).getUser_id());    //service.modify(map);    restoretable(map);   //---------------    //System.out.println(map);  //System.out.println("恢复成功");    request.getSession().setAttribute("dbmap", map);    msg1 = "tiaozhuan";    return "success";  }   //对特定表的处理 public void copytable() throws Exception {  Runtime rt = Runtime.getRuntime();     // 调用 mysql 的 cmd:    //调用mysql的cmd:备份某个表   //Process child = rt  // .exec("D:/db/mysql/mysql-5.0.45-win32/bin/mysqldump -uroot -pmysql --set-charset=utf8 ibtts t_a_dbbak");// 设置导出编码为utf8。这里必须是utf8     Process child = rt.exec(databaseDirectory+"/"+copyDbCmd+" --no-defaults "+"-u"+userName+" "+"-p"+userPwd+" "+"--set-charset=utf8"+" "+databaseName+" "+"t_a_dbbak");// 设置导出编码为utf8。这里必须是utf8   // 把进程执行中的控制台输出信息写入.sql文件,即生成了备份文件。注:如果不对控制台信息进行读出,则会导致进程堵塞无法运行   InputStream in = child.getInputStream();// 控制台的输出信息作为输入流    // System.out.println(databaseDirectory+"/"+copyDbCmd+" --no-defaults "+"-u"+userName+" "+"-p"+userPwd+" "+"--set-charset=utf8"+" "+databaseName+" "+"t_a_dbbak");     InputStreamReader xx = new......

原文转载:http://www.shaoqun.com/a/859322.html

跨境电商:https://www.ikjzd.com/

shopyy:https://www.ikjzd.com/w/1661

欧麦:https://www.ikjzd.com/w/2085

智赢:https://www.ikjzd.com/w/1511


packagecom.itenp.gen.action;importjava.io.BufferedReader;importjava.io.FileInputStream;importjava.io.FileOutputStream;importjava.io.InputStream;importjava.io.InputStreamReader;importjava.io.OutputStre
递四方:https://www.ikjzd.com/w/1066
3suisses:https://www.ikjzd.com/w/412
亚马逊承认暗箱操作,姐夫出庭解释.....:https://www.ikjzd.com/articles/126887
把竞争对手从自己Listing页面挤掉,备战2020节日季你不知道的3个广告技巧:https://www.ikjzd.com/articles/126896
Prime Day或撞"黑五网一",亚马逊卖家8月该做些什么?:https://www.ikjzd.com/articles/126883
亚马逊listing转化率优化系列教程一:怎样优化listing图片?:https://www.ikjzd.com/articles/126908
老头一边吃奶一边摸下面 被老头做的死去活来:http://lady.shaoqun.com/a/247872.html
又粗又长进美妇后菊 肥臀浪妇太爽了快点再快点:http://lady.shaoqun.com/m/a/247118.html
女海王阵型!不告诉男朋友就勾搭富二代!数百万粉丝,Tik Tok女人,网络名人,做了很多轮:http://lady.shaoqun.com/a/410933.html
清迈的一个天桥小舒林成同志,被居民举报:http://lady.shaoqun.com/a/410934.html
女人为什么选择"暧昧"?倾听中年妇女的心声:http://lady.shaoqun.com/a/410935.html
独立站高昂流量成废品,如何操作才能起死回生?(上):https://www.ikjzd.com/articles/146487

没有评论:

发表评论