Web环境下MS SQL Server中数据的磁带备份和恢复
2008-04-02 10:45:47来源:互联网 阅读 ()
和在Web信息系统中要实现完整的磁带数据备份及恢复功能。从理论和实践上阐述了如何利用SQL中现有的数据库备份和恢
复的命令连同NT中的IDC技术。
关键词:Web信息系统;磁带数据备份;桥数据库;IDC文档;数据恢复
1 引言
实现磁带备份数据的功能有两方面的困难:首先,MS SQL Server(以下简称SQL)所提供的数据库的整体备份及恢复
功能不能直接满足本系统需要的数据滚动备份。其次,需要解决如何在Web环境下实现磁带数据备份功能。
利用SQL中现有的数据库备份和恢复的命令连同NT中的IDC技术,实现SQL数据库中数据滚动备份到磁带的功能。本系统
所实现功能既能确保近一段时间的数据总在数据库中,又能确保系统管理员可随时恢复备份数据,供用户查询。本文所实
现的功能具备普遍的意义,特别适用于中小型企业研发基于Intranet技术的管理信息系统。
2 磁带数据备份及恢复的工作过程
为了充分利用SQL中现有的数据库备份和恢复功能,以降低实现磁带数据备份的代价,我们特地在硬盘上建立了一个和
磁带的容量相当的数据库,我们称之为桥数据库,如FJJDBBK。可方便地实现数据的滚动备份了。其工作过程是:管理员把
某月的数据从主数据库移到桥数据库中;然后用SQL的备份功能把桥数据库备份到磁带上。用户需要查看磁带中的历史数据
时,系统又用SQL的恢复备份功能把磁带中的数据恢复到桥数据库中,用户直接在桥数据库中查阅历史数据。此外,在数据
备份到磁带后,在进行下次数据备份前,必须清空备份数据库中的数据。为了提高工作效率,我们建立了一个空白桥数据
库(没有数据时的桥数据库)。每次进行磁带备份数据之前,就用此空白数据库恢复桥数据库。空白数据库文档建立后要
保存好,不可随便删除。
建立该备份空白数据库过程为:先建立主数据库FJJDBBK,然后在FJJDBBK中建立和当前数据库中相同结构的表。建立
这些表结构时最好的方法是先用Enterprise Manager的Object菜单下的Generate SQL Scripts功能生成建立这些表的
Scripts文档,然后选择FJJDBBK数据库,用Enterprise Manager的Tools菜单下的Query Analyzer功能运行该文档,就建立
了这些所需表。显然,这时的FJJDBBK为空数据库。我们再利用备份命令或运行Tools菜单下的Backup/Restore功能备份该
空数据库。
3 磁带数据备份及恢复的实现
在NT中,Web服务器IIS(Internet Information Server)提供了完善的访问SQL的技术IDC。IDC是个DLL文档
(HTTPODBC.DLL),其实,他通过ODBC接口可访问各种数据库。在具体实现Web页面访问数据库时,需建立两种类型的文
件:IDC文档(*.idc)和HTML模板文档(*.htx)。IDC文档用于控制数据库的访问。他一般由两部分组成:
.文档头 指明系统数据源,模板文档名,用户名及口令。有时还包括一些有关检索数据库方面的参数配置。
.文档主体 这部分内容以"SQLStatement:"为起始标志,然后写操纵数据库的标准SQL语句。注意,每条语句以" "号
开头,他作为区分每条SQL语句的标志。需要强调的是,对于MS SQL数据库,IDC可用其任何标准的命令及函数。例如定义
变量,控制数据流等(见实例)。
IDC的处理流程如下:首先,Web服务器IIS分析浏览器传来的URL字符串。假如当前字符串以"*.idc"结尾,就将该IDC
请求传给IDC接口模块,IDC将依次读取并解释IDC文档的内容,通过ODBC模块向数据库服务器发服务请求;数据库服务器将
执行结果通过ODBC接口返回给IDC模块。接着IDC模块把结果插入指定的的模板文档,形成一个实际的HTML文档交给IIS;最
后由IIS将该HTML返回浏览器。
在Web信息系统中要实现完整的磁带数据备份及恢复功能需要实现以下三个功能:"数据备份"功能、"数据恢复"功能
和"清理数据"功能。"数据备份"功能在确保系统管理员操作的前提下,根据用户输入的所要备份数据的起始日期和终止日
期,从主数据库把要备份的数据转存到桥数据库中,然后运用SQL的DUMP命令实现该功能。"数据恢复"功能则在确保系统管
理员操作的前提下,提供"恢复桥数据库"和"恢复空白桥数据库"的功能。只要运用SQL的LOAD命令就可实现上述功能;同
样,"清理数据"功能也要确保在系统管理员操作的前提下,根据用户输入的所要删除数据的起始日期和终止日期,运用SQL
中的DELETE命令删除当前数据库中数据。因此。为了"数据备份"功能和"清理数据"功能的顺利实施,需要每个表都有归档
时间字段。
实现本系统磁带数据备份和恢复功能的部分IDC文档如下:
/*BKUP.IDC*/
Datasource: Web SQL
Template: BKUP.htx
Username: sa
Password: sa
SQLStatement:
if %jb%=1
/*判断系统维护员*/
SELECT qsrq=convert(varchar(12),getdate(),1),
zzrq=convert(varchar(12), dateadd(day,1,getdate()),1)
/*预置起始日期和终止日期*/
/*BKUPCZ.IDC*/
Datasource: Web SQL
Template: BKUPCZ.htx
Username: sa
Password: sa
SQLStatement:
INSERT FJJDBBK.DBO.JKLD SELECT * FROM FJJDB.DBO.JKLD
where convert(varchar(12),gdsj,1)>=′%QSRQ%′
and convert(varchar(12),gdsj,1)< =′%ZZRQ%′
…………
/*把当前数据库中选定的数据转存到桥数据库中*/
DUMP DATABASE FJJDBBK TO TAPE = ′\.tape0′ WITH INIT, NOUNLOAD
/*备份数据*/
SELECT TS=′备份数据库操作已完成!′
/*HUIF.IDC*/
Datasource: Web SQL
Template: HUIF.htx
Username: sa
Password: sa
SQLStatement:
if %jb%=1
begin
LOAD DATABASE FJJDBBK FROM TAPE=′\.TAPE0′ WITH
NOUNLOAD
/*恢复备份数据*/
SELECT TS=′恢复数据库操作已完成!′ /*
end
/*QLSJKCZ.IDC*/
Datasource: Web SQL
Username: sa
Password: sa
Template: QLSJKCZ.htx
SQLStatement:
delete FJJDB.DBO.JKLD
where convert(varchar(12),gdsj,1)>=′%QSRQ%′ and
convert(varchar(12),gdsj,1)<=′%ZZRQ%′
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash