Username: Password:

教您轻松掌控Informix数据备份的小技巧
来源:作者: 发布时间:2008-05-27 03:26:30

在大型项目的研发中,一个项目组通常会在小型的模拟环境中进行初步研发,待系统初步稳定后,再把研发环境移到新系统中,最后才把旧系统转换到新系统中去。但在模拟环境中,一般数据库服务器的配置都较低,而且不会有专门的数据备份措施,一旦掉电或误操作,便容易出现数据丢失、数据库毁坏的情况,研发人员的一番心血便会白费。因此,需要一种简单而又有效的数据备份方法。

我们假设模拟环境的数据库服务器的操作系统是Rerhat Linux 7,数据库服务器为Informix Online Dynamic Server 7.0,需要备份的数据库名称为dbtemp。在研发过程中,我们需要能对数据库表结构和其中的数据每天都能定时进行自动备份。因此我们需要使用crontab进行工作日程安排,crontab是操作每个用户的守护程式和该执行的时间表。

 

crontab文档的格式:M H D m d cmd。  
M: 分钟(0-59)。  
H:小时(0-23)。   
D:天(1-31)。   
m: 月(1-12)。   
d: 一星期内的天(0~6,0为星期天)。

 

cmd要运行的程式,程式被送入sh执行,这个shell只有USER,HOME,SHELL这三个环境变量。

 

root用户使用crontab -e命令编辑crontab文档,在本例中,文档内容如下:

 

#backup zhdata start;  
24 15 * * * su -l -c "dbschema -d 
dbtemp -ss /opt/informix/data/dbtemp.sql" informix  
25 15 * * * su -l -c "dbaccess 
dbtemp /opt/informix/data/create_unload.sql" informix  
27 15 * * * su -l -c "dbaccess 
dbtemp /opt/informix/data/unload.sql" informix
#backup zhdata end;

文档中的第一条语句指定每天下午3点24分创建数据库dbtemp模式文档dbtemp.sql;第二条语句指定每天下午3点25分使用dbaccess执行create_unload.sql 文档,create_unload.sql文档内容如下:

 

UNLOAD TO /opt/Informix/data/unload.sql DELIMITER ’;’  
SELECT "unload to /opt/informix/data/"||tabname||  
".txt delimiter ’

 

这是一条嵌套式SQL语句,能够把数据库中的除系统表以外的任何表找出来。假设数据库中除了系统表外,更有用户表userinfo1,userinfo2,.…,userinfon,那么执行该语句后生成的unload.sql文档内容将为:

 

unload to /opt/Informix/data/userinfo1.txt 
delimiter ’

然后第3条语句指定每天下午3点27分使用dbaccess执行unload.sql文档,unload语句完成的是把表中的数据内容倒出成以指定分隔符分隔字段的文本文档;在本例中,unload.sql文档实现导出数据库中出系统表以外的各表数据,生成以’$’符号分隔的文本文档,即把数据库除系统表以外的各表数据都导成以’$’符号分隔的文本文档,存放在/opt/Informix/data目录下面。这样,这个简单的数据备份便完成了。

select * from "||tabname FROM systables WHERE tabid >; 99

 

这是一条嵌套式SQL语句,能够把数据库中的除系统表以外的任何表找出来。假设数据库中除了系统表外,更有用户表userinfo1,userinfo2,.…,userinfon,那么执行该语句后生成的unload.sql文档内容将为:

 

___FCKpd___3

然后第3条语句指定每天下午3点27分使用dbaccess执行unload.sql文档,unload语句完成的是把表中的数据内容倒出成以指定分隔符分隔字段的文本文档;在本例中,unload.sql文档实现导出数据库中出系统表以外的各表数据,生成以’$’符号分隔的文本文档,即把数据库除系统表以外的各表数据都导成以’$’符号分隔的文本文档,存放在/opt/Informix/data目录下面。这样,这个简单的数据备份便完成了。

select * from userinfo1; unload to /opt/Informix/data/userinfo1.txt delimiter ’

然后第3条语句指定每天下午3点27分使用dbaccess执行unload.sql文档,unload语句完成的是把表中的数据内容倒出成以指定分隔符分隔字段的文本文档;在本例中,unload.sql文档实现导出数据库中出系统表以外的各表数据,生成以’$’符号分隔的文本文档,即把数据库除系统表以外的各表数据都导成以’$’符号分隔的文本文档,存放在/opt/Informix/data目录下面。这样,这个简单的数据备份便完成了。

select * from "||tabname FROM systables WHERE tabid >; 99

 

这是一条嵌套式SQL语句,能够把数据库中的除系统表以外的任何表找出来。假设数据库中除了系统表外,更有用户表userinfo1,userinfo2,.…,userinfon,那么执行该语句后生成的unload.sql文档内容将为:

 

___FCKpd___3

然后第3条语句指定每天下午3点27分使用dbaccess执行unload.sql文档,unload语句完成的是把表中的数据内容倒出成以指定分隔符分隔字段的文本文档;在本例中,unload.sql文档实现导出数据库中出系统表以外的各表数据,生成以’$’符号分隔的文本文档,即把数据库除系统表以外的各表数据都导成以’$’符号分隔的文本文档,存放在/opt/Informix/data目录下面。这样,这个简单的数据备份便完成了。

select * from userinfo2; …… unload to /opt/Informix/data/userinfo1.txt delimiter ’

然后第3条语句指定每天下午3点27分使用dbaccess执行unload.sql文档,unload语句完成的是把表中的数据内容倒出成以指定分隔符分隔字段的文本文档;在本例中,unload.sql文档实现导出数据库中出系统表以外的各表数据,生成以’$’符号分隔的文本文档,即把数据库除系统表以外的各表数据都导成以’$’符号分隔的文本文档,存放在/opt/Informix/data目录下面。这样,这个简单的数据备份便完成了。

select * from "||tabname FROM systables WHERE tabid >; 99

 

这是一条嵌套式SQL语句,能够把数据库中的除系统表以外的任何表找出来。假设数据库中除了系统表外,更有用户表userinfo1,userinfo2,.…,userinfon,那么执行该语句后生成的unload.sql文档内容将为:

 

___FCKpd___3

然后第3条语句指定每天下午3点27分使用dbaccess执行unload.sql文档,unload语句完成的是把表中的数据内容倒出成以指定分隔符分隔字段的文本文档;在本例中,unload.sql文档实现导出数据库中出系统表以外的各表数据,生成以’$’符号分隔的文本文档,即把数据库除系统表以外的各表数据都导成以’$’符号分隔的文本文档,存放在/opt/Informix/data目录下面。这样,这个简单的数据备份便完成了。

select * from userinfon;

然后第3条语句指定每天下午3点27分使用dbaccess执行unload.sql文档,unload语句完成的是把表中的数据内容倒出成以指定分隔符分隔字段的文本文档;在本例中,unload.sql文档实现导出数据库中出系统表以外的各表数据,生成以’$’符号分隔的文本文档,即把数据库除系统表以外的各表数据都导成以’$’符号分隔的文本文档,存放在/opt/Informix/data目录下面。这样,这个简单的数据备份便完成了。

select * from "||tabname FROM systables WHERE tabid >; 99

 

这是一条嵌套式SQL语句,能够把数据库中的除系统表以外的任何表找出来。假设数据库中除了系统表外,更有用户表userinfo1,userinfo2,.…,userinfon,那么执行该语句后生成的unload.sql文档内容将为:

 

___FCKpd___3

然后第3条语句指定每天下午3点27分使用dbaccess执行unload.sql文档,unload语句完成的是把表中的数据内容倒出成以指定分隔符分隔字段的文本文档;在本例中,unload.sql文档实现导出数据库中出系统表以外的各表数据,生成以’$’符号分隔的文本文档,即把数据库除系统表以外的各表数据都导成以’$’符号分隔的文本文档,存放在/opt/Informix/data目录下面。这样,这个简单的数据备份便完成了。

喜欢本文,那就收藏到:

    Del.icio.us Google书签 Digg Live Bookmark Technorati Furl Yahoo书签 Facebook 百度搜藏 新浪ViVi 365Key网摘 天极网摘 和讯网摘 博拉网 POCO网摘 添加到饭否 QQ书签 Digbuzz我挖网
相关评论  我也要评论
还没有关于此文章的相关评论!
  • 昵称: (为空则显示guest)
  • 评论分数: ★ ★ ★★★ ★★★★ ★★★★★
  • 评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。