收藏本站 
广告服务 
网站地图 
>> 本频道近100000余篇各类电脑技术、网络技术、软件技术、网页及平面设计等方面的电脑教程,我们的原则:不是精华拒不收录!
先飞电脑技术网技术文章数据库开发Informix
网络编程 | 网站建设 | 网络技术 | 设计教程 | 软件教学 | 程序开发 | 数据库开发 | 教育认证 | 硬件维护 | 媒体动画 | 机械电子 |

轻松掌握Informix数据备份的小技巧

[ 作者:佚名    转贴自:网络转载    阅读次数:106    更新时间:2007-9-17 11:36:00   录入:刘光勇 ]         
    在大型项目的开发中,一个项目组通常会在小型的模拟环境中进行初步开发,待系统初步稳定后,再把开发环境移到新系统中,最后才把旧系统切换到新系统中去。但在模拟环境中,一般数据库服务器的配置都较低,而且不会有专门的数据备份措施,一旦掉电或误操作,便容易出现数据丢失、数据库毁坏的情况,开发人员的一番心血便会白费。因此,需要一种简单而又有效的数据备份方法。

我们假设模拟环境的数据库服务器的操作系统是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 '$' select * from "||tabname  
FROM systables WHERE tabid >; 99

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

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

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

文章首页【加入到收藏夹】告诉好友】【打印此文】【关闭窗口
  版权声明:本站提供的“轻松掌握Informix数据备份的小技巧”版权归文章所有者,转载请注明出处!
 ·上一篇文章:解析Informix初始化都做了些什么      ·下一篇文章:正确理解Informix的系统结构
相关文章
·轻松更改Excel 2007中的字体或字号[41]
·轻松应对创建存储过程时出现失败的情况[85]
·轻松掌握SQL Server的数据同步技术[78]
·轻松掌握Informix数据备份的小技巧[106]
·轻松掌握数据库复制到Windows CE设备.[54]
网站主页 | 收藏本页 | 联系我们 | 广告服务 | 站点地图 | 会员注册 | 招聘信息 | 内容指正

联系QQ:先飞电脑技术网站事务联系QQ,点击可以直接留言. 32933427 电话:13710542091 [世界排名] 鄂ICP备05005890号 先飞电脑教程网