JAVA实现数据库备份与还原

更新时间:2023-05-12 21:26:39 阅读: 评论:0

JAVA实现数据库备份与还原[MYSQL为例飘动]
      数据库数据的备份与还原最好是使用数据库自带的客户端软件来实现,JAVA可以通过调用mysqldumpmysql客户端软件分别进行mysql数据库的备份还原,当然前提是JAVA服务器必须安装mysql客户端软件,但是也可以通过java telnet登陆数据库服务器实现备份,关于telnet的相关资料请Google.
MYSQL支持的备份方式:
1.使用SELECT INTO ...OUTFILE,例如
SQL代码
1 SELECT * INTO OUTFILE "D:\\test.sql" fields terminatedby ',' lines terminatedby '' from category ; 
生成的文件会存放在数据库服务器上面
SELECT INTO只备份了数据库表中的数据:如下为category备份后的文件内容
XML/HTML代码
2 1,ELECTRONICS,\N 
3 2,TELEVISIONS,1 
4 3,TUBE,2 
5 4,LCD,2 
6 5,PLASMA,2 
7 6,PORTABLE ELECTRONICS,1 
8 7,MP3 PLAYERS,6 
9 8,FLASH,7 
10 9,CD PLAYERS,6 
11 10,2 WAY RADIOS,6 

2.使用BACKUP TABLE,例如
SQL代码
12 BACKUPTABLE test_tableto 'D:\backup'; 
BACKUP只针对MyISAM表格,且在MYSQL 5.1的参考手册中“注释:本语句不理想”;
BACKUP语句效果为拷贝数据库表中的.frm文件到数据库服务器目标目录

3.使用mysqldump程序或mysqlhotcopy脚本
MYSQL 5.1的参考手册中关于mysqldump的说明:“可用来转储数据库或搜集数据库进行备份或将数据转移到另一个SQL服务器(不一定是一个MySQL服务器)。转储包含创建表和/或装载表的SQL语句。“
JAVA可以运用Process类的exec(String str)方法调用系统命令,所以需要在服务器上安装mysqldump程序已完成备份,可以对远程的数据库服务器进行备份(配置河道保洁hostname参数),备份语句具体参数参考MYSQL参考手册
MYSQL备份命令行:
SQL代码
13 mysqldump -hhostname -uurname -ppassword databaname > backupfile 

JAVA代码如下:
Java代码
14 public final String BACKUP_COMMAND ="mysqldump"; 
15 public final String ENCODING ="utf8"; 
16  
17 public boolean backup(String file) { 
18     boolean isSuccess =true; 
19     try { 
20         Runtime rt = Runtime(); 
21         String backupStr =BackupStr(); 
22         logger.infoT(backupStr); 
23         Process process = rt.exec(backupStr); 
24  
25         BufferedReader br =new BufferedReader(new InputStream(), ENCODING)); 
26  
27         String inStr =""; 
28         StringBuffer sb =new StringBuffer(""); 
29         while ((inStr = br.readLine()) !=null) { 
30             sb.append(inStr).append(""); 
31         } 
32         String outStr = sb.toString(); 
33  
34         OutputStreamWriter writer =new OutputStreamWriter(new FileOutputStream(file), ENCODING); 
35         writer.write(outStr); 
36         writer.flush(); 
37  
38         br.clo(); 
39 音序是指什么        writer.clo(); 
40     }catch (Exception e) { 
41         e.printStackTrace(); 
42         isSuccess =fal; 
43     } 
44     return isSuccess; 
45
46  
47 private String getBackupStr() { 
48     String backupStr = BACKUP_COMMAND +" -u" + db.getUrName() +" -p" + db.getPassword() +" -h" + db.getHost() +" --t-chart=" + db.getEncoding() +" " + db.getName(); 
49     return backupStr; 
50
51  

MYSQL还原命令行:
SQL代码
52 mysql  -hhostname -uurname -ppassword databaname < backupfile 
JAVA代码如下:
Java代码
53 public final String REVERT_COMMAND ="mysql"; 
54  
55 public boolean revert(String file) { 
56     try { 
57         Runtime rt = Runtime(); 
58 核桃简笔画        String revertStr =RevertStr(); 
59         Process process = rt.exec(revertStr);  合同解除协议书
60  
61         String inStr; 
62         StringBuffer sb =new StringBuffer(""); 
63         BufferedReader br =new BufferedReader(new InputStreamReader( 
64         new FileInputStream(file), ENCODING)); 
65         while ((inStr = br.readLine()) !=null) { 
66             sb.append(inStr).append(""); 
67         } 
营养不良怎么办68         String outStr = sb.toString(); 
69  
70         OutputStreamWriter writer =new OutputStream(), ENCODING); 
71         writer.write(outStr); 
72         writer.flush(); 
73         br.clo(); 
74 园果        writer.clo(); 
75     }catch (Exception e) { 
76         e.printStackTrace(); 
77         return fal; 
78     } 
79     return true; 
80
81  
82 private String getRevertStr() { 
83     String backupStr = REVERT_COMMAND +" -u" + db.getUrName() +" -p" + db.getPassword() +" -h" + db.getHost() +" " + db.getName(); 
84     return backupStr; 
85

mysqlhotcopy程序,MYSQL 5.1的参考手册的说明:"如果你在服务器上进行备份,并且表均为MyISAM,它运行在UnixNetWare"
实现原理和mysqldump一样,这里暂不详细说明
附上mysqldump备份后的文件的内容:DROP TAB
XML/HTML代码
86 CREATE TABLE `category` ( 
87   `category_id` int(11) NOT NULL auto_increment, 
88   `name` varchar(20) NOT NULL, 
89   `parent` int(11) default NULL, 
90   PRIMARY KEY  (`category_id`) 
91 )ENGINE=MyISAM DEFAULTCHARSET=latin1 ROW_FORMAT=REDUNDANT; 
92  
93 -- 
94 -- Dumping data for table `category` 
95 -- 
96  
97  
98 /*!40000 ALTER TABLE `category` DISABLE KEYS */; 
99 LOCK TABLES `category` WRITE; 
100 INSERT INTO `category` VALUES (1,'ELECTRONICS',NULL),(2,'TELEVISIONS',1),(3,'TUBE',2),(4,'LCD',2),(5,'PLASMA',2),(6,'PORTABLE ELECTRONICS',1),(7,'MP3 PLAYERS',6),(8,'FLASH',7),(9,'CD PLAYERS',6),(10,'2 WAY RADIOS',6); 
101 UNLOCK TABLES; 
102 /*!40000 ALTER TABLE `category` ENABLE KEYS */; 

数据库的备份import java.io.IOException;
import javax.swing.JOptionPane;
public class JavaOutputOracle {
 public static void main(String[] args) {
  Runtime rt = Runtime();
  Process procesxp = null;// 创建一个本机进程
  String exp = "exp  scott/tiger@oracle  file=d:/gengen.dmp";
  try {
   procesxp = rt.exec(exp);
   if (procesxp.waitFor() != 0) {
    JOptionPane.showMessageDialog(null, "数据库备份失败");
   } el {
    JOptionPane.showMessageDialog(null, "数据库备份成功");
   }
  } catch (IOException e) {
   e.printStackTrace();
  } catch (InterruptedException e) {
   e.printStackTrace();
  }
 }
}
数据的恢复:
import java.io.IOException;
import javax.swing.JOptionPane;
public class OracleInput{
 public static void main(String[] args) {
  Runtime rt = Runtime();
  Process procesxp = null;
  String imp = "imp  scott/tiger@oracle  file=d:/gengen.dmp";
  try {
一般过去时的被动语态   procesxp = rt.exec(imp);
   if (procesxp.waitFor() != 0) {
    JOptionPane.showMessageDialog(null, "没有备份的数据库信息文件");
   }
  } catch (IOException e) {
   e.printStackTrace();
  } catch (InterruptedException e) {
   e.printStackTrace();
  }

本文发布于:2023-05-12 21:26:39,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/82/604629.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:数据库   备份   文件   语句   服务器   实现   还原
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图