版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第11章
数据备份、恢复和报表
数据库的导入导出备份概述备份类型创建备份设备数据库备份的执行恢复(还原)概述恢复(还原)数据库概述恢复(还原)数据库数据库的导入导出
通过导入导出操作可以在SQLServer2008和其他异类数据源(例如Excel或Oracle数据库)之间轻松地移动数据。例如,可以将数据从Excel应用程序导出到数据文件,然后将该数据文件导入到SQLServer表中。
导出是指将数据从SQLServer表复制到数据文件中;导入是指将数据从数据文件加载到SQLServer表中。
在SQLServer2008中,可以将数据表中的数据在
SQLServerManagement
Studio中导出(两种途径进行导出)。操作步骤如下图所示。
在“导入导出向导中”依次选择好数据源,导出的目标,要导出的具体数据(可以根据需要是要基础数据还是综合数据),最后进行导出。备份概述:MicrosoftSQLServer2008提供了高性能的备份和还原机制。数据库备份可以创建备份完成时数据库内存在的数据的副本,这个副本能在遇到故障时恢复数据库。这些故障包括:媒体故障,硬件故障,用户操作错误,自然灾害等。数据库备份对于例行的工作(例如,将数据库从一台服务器复制到另一台服务器、设置数据库镜像)也很有用。对SQLServer数据库或事务日志进行备份时,数据库备份记录了在进行备份这一操作时数据库中所有数据的状态,以便在数据库遭到破坏时能够及时地将其恢复。SQLServer备份数据库是动态的,在进行数据库备份时,SQLServer允许其他用户继续对数据库进行操作。备份类型描述完整备份完整备份包含所有数据文件和部分事务日志事务日志备份所有数据库更改差异备份备份上一次完整数据库备份之后被更改的数据库部分文件或文件组备份制定的文件或文件组(大型数据库完整备份不可取)
备份类型:恢复模式描述简单恢复模式数据库的完整或差异副本截断事务日志完整恢复模式包括数据库备份和事务日志备份大容量日志恢复包括数据库和事务日志备份,但使用较少的日志空间
恢复模式中包含的备份类型:以下情况应采用完整数据库备份:数据库较小数据库具有很少的数据修改操作或是只读数据库时如果采用完整数据库备份,则要定期清除事务日志星期日星期一星期二完整数据库备份策略:使用数据库和事务日志备份策略的场合:修改频繁的数据库完整备份耗时太长星期日星期一数据库和事务日志备份策略:使用差异备份策略的场合:数据库频繁修改需要进行最小化备份时单独备份事务日志星期一星期二增量(差异)备份策略:使用文件或文件组备份策略的场合:超大型数据库完整备份时间太长单独备份事务日志可能管理比较复杂星期日星期一星期二星期三数据文件1数据文件2数据文件3文件或文件组备份策略:多媒体:大批量日志备份选项
在这个交互式多媒体中,企业的数据库每天将导入5百万条数据,这会给事务日志备份带来很大负担。通过修改数据库选项,可以解决这个问题。创建备份设备:
备份或还原操作中使用的磁带机或磁盘驱动器称为“备份设备”。在创建备份时,必须选择要将数据写入的备份设备。MicrosoftSQLServer2008可以将数据库、事务日志和文件备份到磁盘和磁带设备上。
使用SQLServer管理平台创建备份设备:在SQLServer管理平台中,选择想要创建备份设备的『服务器』,打开『服务器对象』文件夹。
执行备份操作必须拥有对数据库备份的权限许可,SQLServer只允许系统管理员、数据库所有者和数据库备份执行者备份数据库。备份操作的权限:然后弹出备份设备对话框,如下图所示。
在备份设备图标上右击,从弹出的快捷菜单中选择『新建备份设备』选项,如图所示。
使用系统存储过程创建备份设备:
在SQLServer中,可以使用sp_addumpdevice语句创建备份设备,其语法形式如下:sp_addumpdevice{‘device_type’}[,’logical_name’][,’physical_name’][,{{controller_type|’device_status’}}]举例:在磁盘上创建了一个备份设备(test_backup)。程序清单如下:USEmasterEXECsp_addumpdevice‘disk’,‘test_backup’,‘C:\ProgramFiles\MicrosoftSQLServer\MSSQL\BACKUP\test_backup.bak’数据库备份的执行:
使用SQLServer管理平台进行备份:在SQLServer管理平台中,展开『数据库』文件夹,右击所要进行『备份的数据库』图标,在弹出的快捷菜单中选择『任务』选项,再选择『备份数据库』,如图所示。
出现SQLServer备份对话框,如图所示。图中有两个页框,即“常规”和“选项”页框。
单击『添加』按钮可以选择将备份添加备份文件还是设备,如下图所示。
备份数据库的『选项』页框,如图:
使用备份向导:
在SQLServer管理平台中,点击菜单中的模板资源管理器。展开『backup』,再双击『backupdatabase』。在『连接到数据库引擎』对话框中,填写连接信息,再单击『连接』。此时将打开一个新查询编辑器窗口,其中包含『备份数据库』模板的内容,如图所示。
按照backupdatabase的语法规则,书写数据库备份的sql语句,完成后执行此语句,即可完成数据库备份的操作。Backup语句的语法形式如下:Backupdatabase{database_name|@database_name_var}TO<backup_file>[,…n][WITH[[,]FORMAT][[,]{INIT|NOINIT}][[,]RESTART]]<backup_file>::={backup_file_name|@backup_file_evar}|{disk|tape}={temp_file_name|@temp_file_name_evar}举例:创建一个名为AdventureWorksBack的命名备份设备,并执行完整的数据库备份。--创建一个名为AdventureWorksBack的命名备份设备--设备存储在D:\MyBachupDir目录下--执行一个完整的数据库备份以备份到AdventureWorksBack文件中程序清单如下:USEAdventureWorksEXECsp_addumpdevice‘disk’,‘AdventureWorksBack’,‘D:\MyBachupDir\AdventureWorksBack.bak’BACKUPDATABASEAdventureWorksTOAdventureWorksBack1、BACKUPDATABASEAdventureWorksTOAdventureWorksBackWITHINIT注意以下语句的不同之处:2、BACKUPDATABASEAdventureWorksTOAdventureWorksBackWITHNOINIT3、BACKUPDATABASEAdventureWorksTODISK=‘D:\MyBachupDir\AdventureWorksBack.bak’举例:为日志创建一个备份设备,并备份AdventureWorks数据库的事务日志。--创建一个名为AWBackLog的备份设备,设备存储在D:\Bachup目录下--备份AdventureWorks数据库的事务日志到备份设备程序清单如下:USEAdventureWorksEXECsp_addumpdevice‘disk’,‘AWBackLog’,‘D:\Bachup\AWBackLog.bak’BACKUPLOGAdventureWorksTOAWBackLog举例:在临时的备份文件上创建增量(差异)备份。--在临时的备份磁盘文件上创建名为MyDiffBackup的差异备份(D:\MyData
)程序清单如下:BACKUPDATABASEAdventureWorksTODISK=‘D:\MyData\MyDiffBackup.bak’WITHDIFFERENTIAL举例:用以下代码备份了数据库中某个文件组的Orders2文件。PhoneOrders数据库包含三个文件:Orders1、Orders2和Orders3。事务日志存储在Orderlog文件中。已存在以下备份文件OrderBackup1、OrderBackup2、OrderBackup3、OrderBackupLog。--备份数据库中某个文件组的Orders2文件以及数据库的日志文件。程序清单如下:BACKUPDATABASEPhoneOrdersFILE=Orders2TOOrderBackup2BACKUPLOGPhoneOrdersTOOrderBackupLog多媒体:进行完整备份
在这个交互式多媒体中,你需要对数据库执行完整备份。你可以了解到通过SSMS如何建立备份设备,以及设置完整备份的选项。多媒体:进行事务日志备份
在这个交互式多媒体中,你需要对数据库执行事务日志备份。你可以了解到通过SSMS如何建立事务日志备份,以及设置事务日志备份的选项。恢复(还原)概述:
场景:你所在的企业的数据库库拥有一套完整的备份策略:每周日晚上执行完整备份,每天晚上执行差异备份,每天10点、12点、14点和16点执行事务日志备份。某个周三的下午13点,用户报告说不能访问数据库。作为DBA,你检查时发现数据库发生了严重的故障,存储数据库文件的硬盘无法工作。这时你将会如何处理?
解决办法:你为服务器更换了新硬盘,使用存储在另外一个盘上的备份文件进行故障恢复。先使用上周日晚的完整备份文件进行还原;再使用周二晚上的差异备份文件进行还原;最后使用当天中午12点的事务日志备份进行了还原。还原的工作方式:
还原是从备份中复制数据并将记录的事务应用于此数据,以使其前滚到目标恢复点的过程。恢复是保持数据库一致性并使之处于可用状态的操作的完整集合。使用NORECOVERY和RECOVERY选项:还原期间的恢复状态由RESTORE语句中的NORECOVERY和RECOVERY选项决定。RECOVERY选项是SQLServer默认的选项。当RECOVERY选项与最后一个要还原的事务日志一起使用或用于完整数据库还原时,在恢复完成后数据库可供用户使用。注意:若有额外的事务日志或必须还原的差异备份,则不能使用此选项。
当要还原多个备份时,应使用NORECOVERY选项。要为除最后一个要还原的备份之外的所有备份指定NORECOVERY选项。对于NORECOVERY选项,还原完数据库后,数据库才能为用户使用。恢复(还原)数据库概述:
数据库备份后,一旦系统发生崩溃或者执行了错误的数据库操作,就可以从备份文件中还原数据库。
数据库还原是指将数据库备份加载到系统中的过程。系统在还原数据库的过程中,自动执行安全性检查、重建数据库结构以及完成填写数据库内容。
SQLServer还原数据库时,根据数据库备份文件自动创建数据库结构,并且还原数据库中的数据。
由于数据库的还原操作是静态的,所以在还原数据库时,必须限制用户对该数据库进行其他操作,因而在还原数据库之前,首先要设置数据库访问属性。如图所示。
使用SQLServer管理平台还原数据库:打开SQLServer管理平台,在『数据库』上单击鼠标右键,从弹出的快捷菜单中选择『任务』选项,再选择『还原数据库』命令,弹出还原数据库对话框,如图所示。
恢复(还原)数据库:选中『选项』页框,进行其他选项的设置,如图所示
使用T-SQL语句还原数据库:Transact-SQL提供了RESTORE语句还原数据库,其语法形式如下:RESTOREdatabase[FROM<backup_device[],…n>][WITH[[,]FILE=file_number][[,]MOVE‘logical_file_name’TO‘operating_system_file_name’][[,]REPLACE][[,]{NORECOVERY|RECOVERY|STANDBY=undo_file_name}]]<backup_device>::={{backup_device_name|@backup_device_name_evar}|{disk|tape|pipe}={temp_backup_device|@temp_backup_device_var}举例:从backup_company备份设备中还原数据库company。程序清单如下:RESTOREdatabasecompanyFROMbackup_company举例:使用T-SQL语句从完整备份和差异备份中还原。假设完整备份存在于AWBack备份文件中,AWBackDiff文件包含差异备份。--从完整备份AWBack还原数据库AdventureWorks,--回滚未提交事务,使数据库处于用户可以使用的状态,无法还原其他事务日志。程序清单如下:RESTOREDATABASEAdventureWorksFROMAWBackWITHNORECOVERYRESTOREDATABASEAdventureWorksFROMAWBackDiffWITHRECOVERY
还原事务日志的方法:还原事务日志将日志中的更改应用到数据库
在还原事务日志之前,先还原完整的数据库备份,再还原最近的差异备份,后按顺序还原自上次完整或差异备份后的所有事务日志备份。在将被还原的最后的日志上使用RECOVERY选项举例:使用T-SQL语句进行还原。假设一个备份文件AWBack中存在完整的数据库AdventureWorks
,另一个文件AWBackLog中存在两个(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论