以下的文章主要描述的是在Web环境之下对MS SQL Server中数据进行磁带备份和恢复的实际操作步骤,其中包括在硬盘上正确的建立一个和磁带的容量相当的数据库,即桥数据库和在Web信息系统中要实现完整的磁带数据备份及恢复功能。
从理论与实践上阐述了如何利用SQL中现有的数据库备份和恢复的命令以及NT中的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 MS SQL Server数据库,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文件如下:
+/*判断系统维护员*/
+/*把当前数据库中选定的数据转存到桥数据库中*/
+/*备份数据*/
+select TS=′备份数据库操作已完成!′
+/*恢复备份数据*/
+SELECT TS=′恢复MS SQL Server数据库操作已完成!′+/*
+/*删除当前数据库中选定的数据*/
+SELECT TS=′删除操作已完成!′
在本系统中,主数据库保证存储4个月数据。系统规定,系统管理员每月月初备份上月的数据到磁带。然后删除前第4个月的数据。实现了当前数据与历史数据的同步查阅,这是Web系统的一个显著的优点。
4 结语
本文介绍了一种特殊的数据磁带备份与恢复的具体实现方法。需要指出的是,数据库备份操作是数据库管理系统非常重要的环节,而数据库备份操作过程又比较复杂,因此,要求我们必须建立完善的规章制度,由专业的系统管理员进行数据库备份和恢复操作。
【编辑推荐】
sql常用语句写法
1、说明:创建数据库
CREATE DATABASE database-name
2、说明:删除数据库
drop database dbname
3、说明:备份sql server
--- 创建 备份数据的 device
USE masterEXEC sp_addumpdevice ’disk’, ’testBack’, ’c:mssql7backupMyNwind_’
--- 开始 备份
BACKUP DATABASE pubs TO testBack
4、说明:创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
根据已有的表创建新表:
A:create table tab_new like tab_old (使用旧表创建新表)B:create table tab_new as select col1,col2… from tab_old definition only
5、说明:
删除新表:drop table tabname
6、说明:
增加一个列:Alter table tabname add column col type
注:列增加后将不能删除。 DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
7、说明:
添加主键:Alter table tabname add primary key(col)
说明:
删除主键:Alter table tabname drop primary key(col)
8、说明:
创建索引:create [unique] index idxname on tabname(col….)
删除索引:drop index idxname
注:索引是不可更改的,想更改必须删除重新建。
9、说明:
创建视图:create view viewname as select statement
删除视图:drop view viewname
10、说明:几个简单的基本的sql语句
选择:select * from table1 where 范围
插入:insert into table1(field1,field2) values(value1,value2)
删除:delete from table1 where 范围
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ ---like的语法很精妙,查资料!
排序:select * from table1 order by field1,field2 [desc]
总数:select count * as totalcount from table1
求和:select sum(field1) as sumvalue from table1

平均:select avg(field1) as avgvalue from table1
最大:select max(field1) as maxvalue from table1
最小:select min(field1) as minvalue from table1
怎么备份SQL Server 2008数据库
一、自动备份数据库1、在电脑开始菜单中选择“sqlserverManagementStudio”双击。 在出现的界面中点击“连接”按钮。 SQLServer2008怎么自动备份数据库2、在出现的“MicrosoftSQLServerManagementStudio”界面中选择“管理”下的“维护计划”右击维护计划,点击“维护计划向导”,SQLServer2008怎么自动备份数据库3、在出现的“SQLServer维护计划向导”界面中点击“下一步”在出现的界面中把名称和说明写上。 然后点击“更改”设顶备份计划在出现的“作业计划属性”界面中,更改执行时间,也就是多久备份一次。 这里该为每天备份。 间隔时间更改为“1”更改执行一次时间为0:00:00也就是在每天的0点自动备份数据。 更改好以后,就可以在下面看到“在每天的0:00:00执行。 将从2014-5-16开始使用计划。 ”然后点击“下一步”按钮在选择维护任务界面中选择要备份的数据库文件。 然后点击下一步。 在选择维护任务顺序中,可以移动要备份的数据库文件的顺序。 然后点击“下一步”在定义“备份数据库完整”界面中,选择数据库后面下拉菜单中的数据库文件。 然后点击“确定”按钮在定义“备份数据库完整”界面里选择备份路径。 然后点击“下一步”在“选择报告选项”界面中设置好“报告文本文件”的路径。 然后点击“下一步”在出现的“完成该向导”界面中会看到设置备份的详细信息。 这样数据库自动备份就成功了。 二、语句备份方式declare@namevarchar(250)set@name=C:\DB1_+convert(varchar(50),getdate(),112)+[你的数据库名称]TODISK=@nameWITHNOFORMAT,NOINIT,NAME=NDB1-完整数据库备份,SKIP,NOREWIND,NOUNLOAD
如何在SQL Server2000中恢复Master数据库
--恢复Master--方法1:重装SQL,但是数据就Over掉了--方法2:重建Master 用到SQL的安装文件, --从安装目录X86\Data中拷取原文件--重建成功后,不要启动SQL Server,以单用户模式进入SQL--SQLserver的安装目录\bin\ -m --还原数据库备份restore--恢复Master--启动SQL SERVERsp_addumpdevicedisk,Mas, E:\如果是Model 数据库损坏,具体过程为:先重建Master数据库,再恢复Model数据库的备份;MSDB的损坏不影响SQL Server的正常运行, 备份还原和用户数据库相同TempDB:SQL Server每次启动的时候,都会使用Model数据库重建,不用备份
发表评论