动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
   数据库 → 阅读文章
  

 Informix数据备份技巧

作者来源:51CTO.com整理  
阅读 数 84 人次 , 2006-3-18 12:01: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目录下面。这样,一个简单的数据备份便完成了。



 本文Tags备份  RealPlayer  
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:开发优质高效的Informix数据库应用程序(1)
· 下一篇:Informix 4GL写的转换成大写金额字串的函数
· MySQL进阶_SELECT篇(二)
· PHP中操作MySQL的需注意的问题
· 为使用 DB2 UDB 配置第三方应用服务器(1)
· Oracle 9i Data Guard进行数据库的灾难防护
· MySQL数据库技术(14)


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077