数据库原理与应用教程 ―SQL Server

Slides:



Advertisements
Similar presentations
第二章 简单的 SQL 语句. 本章要点  创建一个简单的表  SQL 语句介绍  最简单的查询语句 select  带有限制条件的查询  查询结果的排序显示.
Advertisements

2011/11,12 南台資管 吳昭儀. 1. 使用者介面 (User Interface)  使用者操作畫面的安排  Textbox, ComboBox, ListBox, CheckList, … 2. 流程控制 (Process Control)  使用者輸入資料檢查  計算  資料輸出.
数据库系统原理 数据库系统概论 SQL Server 数据库系统原理 3.1 SQL Server 2000 特性 Microsoft SQL Server 2000 的特性包括: 真正的客户机 / 服务器体系结构。 图形化用户界面。 丰富的编程接口工具。 SQL Server 与 Windows.
武汉库得克 软件有限公司 公司简介 发展机遇 特点 一家专注于质量管理平台和整体 解决方案的提供商
Database Management System 資料庫管理系統
第16章 备份与恢复 基 本 概 念 16.1 备份数据库 16.2 恢复数据库 16.3.
第15章 备份与恢复数据库 日志文件 基本概念 恢复数据库的基本原理 数据库故障的种类 备份数据库 备份的内容和时间 备份的一般方法
第四章 数据库管理和使用.
第2讲 Transact-SQL语言.
第5章 索引及视图操作 数据库原理应用与实践 SQL SERver2014(第2版) 主编 贾铁军 科学出版社 编著 陈国秦 万程 邢一鸣
服装数字图书馆 北京服装学院图书馆 2009年12月.
第14章 預存程序 14-1 預存程序的基礎 14-2 建立與執行預存程序 14-3 預存程序的參數傳遞 14-4 預存程序的傳回值
第十三章 SQL Server的安全管理.
資料庫 (Database) SQL Server 2008實作
第3章 SQL的基础知识 数据库管理及应用 3.1 SQL简介 3.2 SQL的数据模型 3.3 标识符 3.4 使用SQL语句管理数据库
数据库概述 简而言之,数据库(DataBase)就是一个存储数据的仓库。为了方便数据的存储和管理,它将数据按照特定的规律存储在磁盘上。通过数据库管理系统,可以有效的组织和管理存储在数据库中的数据。如今,已经存在了Oracle、SQL Server、MySQL等诸多优秀的数据库。在这一章中将讲解的内容包括。
第三章 Management Studio.
第6章 資料庫管理系統 6-1 關聯式資料庫管理系統 6-2 SQL Server資料庫管理系統
创建数据库 MySql创建数据库的语法: CREATE DATABASE 数据库名; 例: CREATE DATABASE mydb;
Visual Basic程序设计 主 编  柳青.
转正述职报告 乐恩公司 史航
第7章 建立資料表與完整性限制條件 7-1 資料型別 7-2 資料表的建立 7-3 建立完整性限制條件 7-4 修改與刪除資料表
第 2 章 SQL Server 2008 R2資料庫安裝設定與管理
建立/修改/刪除資料庫 資料庫組成檔案 建立資料庫: 資料(庫)檔案 交易記錄檔 使用Enterprise Manager工具 自助法:
第六章: 建立資料庫.
第 3 章 SQL Server 2000 伺服器管理初步.
第 8 章 資料的 新增、修改與刪除.
第 3 章 熟悉 SQL Server 的工作平台.
第4章 SQL语言基础及数据库定义 4.1 基本概念 4.2 SQL Server 提供的主要数据类型 4.3 数据定义.
二.資料庫系統建立與管理 Access 資料庫:windows下的單機資料庫 Access 操作 Mysql資料庫介紹.
第 11 章 建立檢視表.
第 14 章 預存程序.
第 7 章 建立資料表與 資料庫圖表.
教 师:曾晓东 电 话: 数据库技术 教 师:曾晓东 电 话:
第 16 章 觸發程序.
班級:博、碩子一甲 授課老師:鐘國家 助教:陳國政
SQL Server 2000 数据库入门.
指導老師:王文彥 老師 學生:王冠樺、鄭培宇、許智惟、黃柏翎 崑山科技大學資訊工程系 2012/01/16
建立/修改/刪除資料表 建立資料表 使用Enterprise Manager工具
第9章 SQL Server的数据库保护技术 教学目标:通过本章学习,了解SQL Server的安全体系结构的含义和安全认证模式的分类;掌握SQL Server登录账号、用户账号及角色的创建方法;熟悉权限的分类,掌握对象权限和语句权限的管理方法;明确SQL Server中数据完整性的种类,掌握数据完整性实现的具体方法;熟悉SQL.
数据保护技术(完整性、并发性、安全性和数据库恢复)
第 6 章 使用者權限.
移动电子商务 第十二章 Windows Mobile应用案例 倚动软件工厂实验室.
《网上报告厅》使用说明 北京爱迪科森教育科技股份有限公司.
Ch4.SQL Server 2005資料庫組成員元件介紹
数据库技术.
第 23 讲 操作系统接口与UNIX系统内核结构 李元金 计算机与信息工程学院 1.
学习要点: 备份的概念 备份的类型 数据库备份的方法 恢复数据库的方法
数据库原理与应用 合肥学院 叶潮流
第3章 关系数据库的创建与维护 Microsoft SQL Server2008 概述 SQL Server数据库基础 数据库的创建与维护
第九章 创建数据库.
第1章 SQL Server 2005概述 教学提示:SQL Server 2005是微软的下一代数据管理和分析解决方案,它给企业级应用数据和分析程序带来更好的安全性、稳定性和可靠性,使得它们更易于创建、部署和管理,从而可以在很大程度上帮助企业根据数据做出更快、更好的决策,提高开发团队的生产力和灵活度,以及在减少总体IT预算的同时,能够扩展IT基础架构以更好地满足多种需求。
4.2 视图 (1) 视图是一个虚拟表,其内容来自对表查询的基础上。
CS, ZJU 4/18/2019 Chapter 7 数据库.
第2章 数据库的创建和管理 学习要点: 2.1 基本概念 2.2 创建数据库 2.3 数据库的管理 2.4 删除数据库
国家“十一五”规划教材 数据库原理与应用教程(第3版).
6 SQL語言與資料庫建置 6-1 SQL語言的基礎 6-2 SQL Server的資料庫結構 6-3 建立使用者資料庫
第 6 章 建立資料庫.
用int类型(4字节)去存具体时间(8字节).
第六類 資料庫備份與回復.
讲课人:王璞 浙江工商职业技术学院.
1 打开 SQL Server 2005 安装盘,单击 SPLASH.HTA 文件进行安装,安装界面如图所示。
第 7 章 建立資料表與資料庫圖表.
第4章 表的创建与维护 4.1 数据类型 4.2 数据完整性约束 4.3 创建数据表 4.4 修改数据表 4.5 删除数据表.
第11章 安全管理 教学提示:数据库安全是关系数据库中的非常重要的方面,包括了系统安全、数据安全、资源管理、用户管理、权限管理、角色管理、口令管理以及授权、认证、审计等相当多方面的内容。本章讲述有关数据库安全方面的知识。 数据库系统的安全性是每个数据库管理员都必须认真考虑的问题。SQL Server.
第9章 视 图 教学提示:用户在查询数据库中的数据时,除了直接查看数据库中的表中的数据以外,还可以通过视图来查看表中的数据,也就是说,视图为用户提供了另外一种查看表中的数据的方式。 视图是一种虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自于定义视图的查询所引用的表,并且在引用视图时动态生成。
树立开放理念 强化管理水平 全面提升来华留学生教育工作水平
11 檢視表的建立 11-1 檢視表的基礎 11-2 建立檢視表 11-3 修改與刪除檢視表 11-4 編輯檢視表的內容.
国家“十一五”规划教材 数据库原理与应用教程(第3版).
(若使用IE瀏覽,請選擇功能表的「瀏覽」「全螢幕」
Presentation transcript:

数据库原理与应用教程 ―SQL Server 第13章数据库的备份与还原

第13章数据库的备份与还原 避免数据丢失是数据库管理员需要面对的最关键的问题之一。尽管在SQL Server 2005中采取了许多措施来保证数据库的安全性和完整性,但故障仍不可避免,仍会影响甚至破坏数据库,造成数据丢失。同时还存在其他一些可能造成数据丢失的因素,例如用户的操作失误、蓄意破坏、病毒攻击和自然界不可抗力等。因此,SQL Server 2005指定了一个良好的备份还原策略,定期将数据库进行备份以保护数据库,以便在事故发生后还原数据库。

第13章数据库的备份与还原 13.1数据库备份概述 对于计算机用户来说,对一些重要文件、资料定期进行备份是一种良好的习惯。如果出现突发情况,比如系统崩溃、系统遭受病毒攻击等,使得原先的文件遭到破坏以至于全部丢失,启用文件备份,就可以节省大量的时间和精力。 数据库备份就是在某种介质上(磁盘、磁带等)创建完整数据库(或者其中一部分)的副本,并将所有的数据项都复制到备份集,以便在数据库遭到破坏时能够恢复数据库。

第13章数据库的备份与还原 13.1数据库备份概述 对SQL Server 2005数据库或事务日志进行备份,就是记录在进行备份这一操作时数据库中所有数据的状态,以便在数据库遭到破坏时能够及时地将其还原。执行备份操作必须拥有对数据库备份的权限许可,SQL Server 2005只允许系统管理员、数据库所有者和数据库备份执行者备份数据库。 SQL Server 2005提供了高性能的备份和还原功能以及保护手段,以保护存储在SQL Server 2005数据库中的关键数据。通过适当的备份,可以使用户能够在发生多种可能的故障后恢复数据,这些故障主要包括:系统故障;用户错误:例如,误删除了某个表或某些数据;硬件故障:例如,磁盘驱动器损坏;自然灾害。

第13章数据库的备份与还原 13.1.1数据库备份计划 创建备份的目的是为了可以恢复已损坏的数据库。但是,备份和还原数据需要在特定的环境中进行,并且必须使用一定的资源。因此,在备份数据库之前,需要对备份内容、备份频率以及数据备份存储介质等进行计划。

第13章数据库的备份与还原 13.1.1数据库备份计划 1.备份内容 备份内容主要包括:系统数据库、用户数据库和事务日志。 (1)系统数据库记录了SQL Server系统配置参数、用户资料以及所有用户数据库等重要信息,主要包括master、msdb和model数据库。 (2)用户数据库中存储了用户的数据。由于用户数据库具有很强的区别性,即每个用户数据库之间的数据一般都有很大差异,所以对用户数据库的备份更为重要。 (3)事务日志记录了用户对数据库中数据的各种操作,平时系统会自动管理和维护所有的数据库事务日志。相比数据库备份,事务日志备份所需要的时间较少,但是还原需要的时间较多。

第13章数据库的备份与还原 13.1.1数据库备份计划 2.备份频率 数据库备份频率一般取决于修改数据库的频繁程度,以及一旦出现意外丢失的工作量的大小,还有发生意外丢失数据的可能性大小。 一般来说,在正常使用阶段,对系统数据库的修改不会十分频繁,所以对系统数据库的备份也不需要十分频繁,只需要在执行某些语句或存储过程导致SQL Server 2005对系统数据库进行了修改的时候备份。 当在用户数据库中执行了加入数据、创建索引等操作时,应该对用户数据库进行备份,此外,如果清除了事务日志,也应该备份数据库。

第13章数据库的备份与还原 13.1.1数据库备份计划 3.备份存储介质 常用的备份存储介质包括硬盘、磁带和命令管道等。具体使用哪一种介质,要考虑用户的成本承受能力、数据的重要程度、用户的现有资源等因素。在备份中使用的介质确定以后,一定要保持介质的持续性,一般不要轻易地改变。

第13章数据库的备份与还原 13.1.1数据库备份计划 4.其它计划 (1)确定备份工作的负责人。 (2)确定使用在线备份还是脱机备份。 (3)确定是否使用备份服务器。 (4)确定备份存储的地方。 (5)确定备份存储的期限。

第13章数据库的备份与还原 13.1.1数据库备份的类型 在SQL Serer系统中,有4种备份类型,分别如下所示: ①完整数据库备份。 ②差异数据库备份。 ③事务日志备份。 ④数据库文件或文件组备份。

第13章数据库的备份与还原 13.1.1数据库备份的类型 1.完整数据库备份 完整数据库备份将备份整个数据库,包括事务日志部分(以便可以恢复整个备份)。完整数据库备份代表备份完成时的数据库,通过包括在备份中的事务日志,可以使用备份恢复到备份完成时的数据库。 创建完整数据库备份是单一操作,通常会安排该操作定期发生。如果数据库主要是只进行读操作,那么完整数据库备份能有效地防止数据丢失。

第13章数据库的备份与还原 13.1.1数据库备份的类型 2.差异数据库备份 差异备份只备份自上一次完整数据库备份发生改变的内容和在差异备份过程中所发生的所有活动。差异数据库备份基于以前的完整数据库备份,因此,这样的完整数据库备份称为“基准备份”。差异备份比完整备份更小、更快,可以简化频繁的备份操作,减少数据丢失的风险。为了减少还原频繁修改数据库的时间,可以执行差异备份。 如果数据库的某个子集比该数据库的其余部分修改得更为频繁,则差异数据库备份特别有用。在这些情况下,使用差异数据库备份,您可以频繁执行备份,并且不会产生完整数据库备份的开销。

第13章数据库的备份与还原 13.1.1数据库备份的类型 3.事务日志备份 备份事务日志可以记录数据库的更改,但前提是在执行了完整数据库备份之后。可以使用事务日志备份将数据库恢复到特定的即时点(如输入多余数据前的那一点)或恢复到故障点。恢复事务日志备份时,SQL Server 2005重做事务日志中记录的所有更改。当SQL Server 2005到达事务日志的最后时,已重新创建了与开始执行备份操作的那一刻完整相同的数据库状态。如果数据库已经恢复,则SQL Server 2005将回滚备份操作开始时尚未完成的所有事务。 一般情况下,事务日志备份比数据库备份使用的资源少,因此可以比数据库备份更经常地创建事务日志备份,经常备份将减少丢失数据的危险。

第13章数据库的备份与还原 13.1.1数据库备份的类型 4.数据库文件或文件组备份 对超大型数据库执行完全数据库备份是不可行的,可以执行数据库文件或文件组备份。 备份文件或文件组时,可以只备份FILE或FILEGROUP选项中指定的数据库文件。 在备份数据库文件或文件组时应考虑以下几点。 ①必须指定逻辑文件或文件组。 ②必须执行事务日志备份,使还原的文件与数据库的其他部分相一致。 ③最多可以指定16个文件或文件组。 ④应制定轮流备份每个文件的计划。

第13章数据库的备份与还原 13.2数据库还原概述 备份是还原数据库最容易和最能防止意外的有效方法。没有备份,所有的数据都可能会丢失,而且将造成不可挽回的损失,这时就不得不从源头重建数据;有了备份,万一数据库被损坏,就可以使用备份来还原数据库。

第13章数据库的备份与还原 13.2.1数据库还原策略 还原数据库是一个装载数据库的备份,然后应用事务日志重建的过程,这是数据库管理员另一项非常重要的工作。应用事务日志之后,数据库就会回到最后一次事务日志备份之前的状况。在数据库备份之前,应该检查数据库中数据的一致性,这样才能保证顺利地还原数据库备份。在数据库的还原过程中,用户不能进入数据库,当数据库被还原后,数据库中的所有数据都被替换掉。数据库备份是在正常情况下进行的,而数据库还原是在诸如硬件故障、软件故障或误操作等非正常的状态下进行的,因而其工作更加重要和复杂。

第13章数据库的备份与还原 13.2.1数据库还原策略 数据还原策略认为所有的数据库一定会在它们的生命周期的某一时刻需要还原。数据库管理员职责中很重要的部分就是将数据还原的频率降到最低,并在数据库遭到破坏之前进行监视,预计各种形式的潜在风险所能造成的破坏,并针对具体情况制定恢复计划,在破坏发生时及时地恢复数据库。

第13章数据库的备份与还原 13.2.1数据库恢复模式 数据库的恢复模式是数据库遭到破坏时还原数据库中数据的数据存储方式,它与可用性、性能、磁盘空间等因素相关。备份和还原操作是在“恢复模式”下进行的,恢复模式是一个数据库属性,它用于控制数据库备份和还原操作基本行为。  每一种恢复模式都按照不同的方式维护数据库中的数据和日志。Microsoft SQL Server 2005系统提供了3种数据库的恢复模式: ①完整恢复模式。 ②简单恢复模式。 ③大容量日志恢复模式。

第13章数据库的备份与还原 13.2.1数据库恢复模式 1.完整恢复模式 完整恢复模式是等级最高的数据库恢复模式。在完整恢复模式中,对数据库的所有的操作都记录在数据库的事务日志中。即使那些大容量数据操作和创建索引的操作,也都记录在了数据库的事务日志中。当数据库遭到破坏之后,可以使用该数据库的事务日志迅速还原数据库。 在完整恢复模式中,由于事务日志记录了数据库的所有变化,所以可以使用事务日志将数据库还原到任意的时刻点。但是,这种恢复模式耗费大量的磁盘空间。除非是那种事务日志非常重要的数据库备份策略,一般不使用这种恢复模式。

第13章数据库的备份与还原 13.2.1数据库恢复模式 2.简单恢复模式 简单恢复模式简略地记录大多数事务,所记录的信息只是为了确保在系统崩溃或还原数据备份之后数据库的一致性。 对于那些规模比较小的数据库或数据不经常改变的数据库来说,可以使用简单恢复模式。当使用简单恢复模式时,可以通过执行完全数据库备份和差异数据库备份来还原数据库,数据库只能还原到执行备份操作的时刻点。执行备份操作之后的所有数据修改都丢失并且需要重建。

第13章数据库的备份与还原 13.2.1数据库恢复模式 3.大容量日志恢复模式 就像完整恢复模式一样,大容量日志恢复模式也使用数据库备份和日志备份来还原数据库。但是,在使用了大容量日志恢复模式的数据库中,其事务日志耗费的磁盘空间远远小于使用完整恢复模式的数据库的事务日志。 此模式简略地记录大多数大容量操作(例如,索引创建和大容量加载),完整地记录其他事务。大容量日志恢复提高大容量操作的性能,常用作完整恢复模式的补充。

第13章数据库的备份与还原 13.2.1数据库恢复模式 在Microsoft SQL Server 2005系统中有两种设置数据库恢复模式的方式,即SQL Server Management Studio和ALTER DATABASE语句。 这里主要介绍前一种方法:在SQL Server Management Studio环境下,选中将要设置恢复模式的数据库,右击数据库,从弹出的快捷菜单中选中“属性”命令,将出现如图13.2所示的“数据库属性”对话框。在该对话框的“选项”页中,可以从“恢复模式”下拉列表中选择恢复模式,图中所示椭圆形区域内指定了“教学库”的恢复模式,即完整恢复模式。

第13章数据库的备份与还原 13.2.1数据库恢复模式 简单恢复模式同时支持数据库备份和文件备份,但不支持事务日志备份。备份非常易于管理,因为始终不会备份事务日志。但是,如果没有日志备份,数据库只能还原到最近数据备份的末尾。如果操作失败,则在最近数据备份之后所做的更新便会全部丢失。 在完整恢复模式和大容量日志恢复模式下,差异数据库备份将最大限度地减少在还原数据库时回滚事务日志备份所需的时间。 事务日志备份只能与完整恢复模型和大容量日志记录恢复模型一起使用。在简单模型下,事务日志有可能被破坏,所以事务日志备份可能不连续,不连续的事务日志备份没有意义,因为基于日志的恢复要求日志是连续的。

第13章数据库的备份与还原 13.3数据库备份操作 1. 在SQL Server Management Studio中备份数据库 (1)在对象资源管理器中展开教学库数据库。 (2)鼠标右击教学库,在弹出的快捷菜单中选择“任务”子菜单,然后选择“备份”命令,弹出“备份数据库-教学库”窗口。 (3)在“数据库”下拉列表框中选择教学库作为准备备份的数据库。在“备份类型”下拉列表框中,选择需要的类型,这是第一次备份,选择“完整”选项,在“名称”文本框中输入要备份的名称。

第13章数据库的备份与还原 13.3数据库备份操作 (4)由于没有磁带设备,所以只能备份到“磁盘”。单击“添加”按钮,重新选择路径和命名文件名,最后单击“确定”按钮 。 (5)单击窗口左边的“选项”选项,对“备份到现有媒体集”选项进行设置,此选项的含义是备份媒体的现有内容被新备份重写。在“备份到现有媒体集”选项中含有两个选项:“追加到现有备份集”和“覆盖所有现有备份集”。其中“追加到现有备份集”是媒体上以前的内容保持不变,新的备份在媒体上次备份的结尾处写入。“覆盖所有现有备份集”是重写备份设备中任何现有的备份。此处选中“追加到现有备份集”单选按钮,单击“确定”按钮,数据备份完成。

第13章数据库的备份与还原 13.3数据库备份操作 2.使用T-SQL语句备份数据库 BACKUP DATABASE { database_name | @database_name_var } TO < backup_device > [ ,...n ] [ WITH     [ BLOCKSIZE = { blocksize | @blocksize_variable } ]     [ [ , ] DESCRIPTION = { 'text' | @text_variable } ]     [ [ , ] DIFFERENTIAL ]     [ [ , ] EXPIREDATE = { date | @date_var }]     [ [ , ] PASSWORD = { password | @password_variable } ]     [ [ , ] FORMAT | NOFORMAT ]     [ [ , ] { INIT | NOINIT } ] ]

第13章数据库的备份与还原 13.3数据库备份操作 其中的参数说明如下: (1){ database_name | @database_name_var }:指定了一个数据库,对该数据库进行完整的数据库备份或差异数据库备份。如果作为变量 (@database_name_var) 提供,则可将该名称指定为字符串常量 (@database_name_var = database name) 或字符串数据类型(ntext 或 text 数据类型除外)的变量。 (2)< backup_device >:指定备份操作时要使用的逻辑或物理备份设备。可以是下列一种或多种形式: ①{ logical_backup_device_name } | { @logical_backup_device_name_var } :备份设备的逻辑名称,数据库将备份到该设备中。 ②{ DISK | TAPE } = 'physical_backup_device_name' | @physical_backup_device_ name_var :允许在指定的磁盘或磁带设备上创建备份。在执行 BACKUP 语句之前不必存在指定的物理设备。如果存在物理设备且 BACKUP 语句中没有指定 INIT 选项,则备份将追加到该设备。

第13章数据库的备份与还原 13.3数据库备份操作 其中的参数说明如下: (3)BLOCKSIZE = { blocksize | @blocksize_variable }:用字节数来指定物理块的大小。在 Windows NT 系统上,默认设置是设备的默认块大小。一般情况下,当 SQL Server 选择适合于设备的块大小时不需要此参数。 (4) DESCRIPTION = { 'text' | @text_variable }:指定描述备份集的自由格式文本。该字符串最长可以有 255 个字符。 (5) DIFFERENTIAL:指定数据库备份或文件备份应该与上一次完整备份后改变的数据库或文件部分保持一致。差异备份一般会比完整备份占用更少的空间。对于上一次完整备份时备份的全部单个日志,使用该选项可以不必再进行备份。 (6)EXPIREDATE = { date | @date_var }:指定备份集到期和允许被重写的日期。如果将该日期作为变量 (@date_var) 提供,则可以将该日期指定为字符串常量 (@date_var = date)、字符串数据类型变量(ntext 或 text 数据类型除外)、smalldatetime 或者 datetime 变量,并且该日期必须符合已配置的系统 datetime 格式。

第13章数据库的备份与还原 13.3数据库备份操作 其中的参数说明如下: (7) PASSWORD = { password | @password_variable }:为备份集设置密码。 PASSWORD 是一个字符串。如果为备份集定义了密码,必须提供这个密码才能对该备份集执行任何还原操作。 (8) FORMAT:指定应将媒体头写入用于此备份操作的所有卷。任何现有的媒体头都被重写。FORMAT 选项使整个媒体内容无效,即格式化备份设备。 (9) NOFORMAT:指定媒体头不应写入所有用于该备份操作的卷中,并且不会格式化备份设备。除非指定了 INIT。 (10)INIT:表示如果备份集已经存在,新的备份集会覆盖旧的备份集。不会格式化备份设备。 (11) NOINIT:表示新的备份集回追加到旧的备份集的后面,不会覆盖。不会格式化备份设备。

第13章数据库的备份与还原 13.3数据库备份操作 在教学库中,创建一个任意的新表,表名“Table”。 [例13-3]创建教学库的差异数据库备份。 BACKUP DATABASE 教学库 TO DISK = 'f:\data\BACKUP\教学库差异备份.Bak' WITH DIFFERENTIAL

第13章数据库的备份与还原 13.4数据库还原操作 SQL Server提供了数据库的两种还原过程,自动还原过程和手动还原过程。 13.4.1自动还原 自动还原是指SQL Serer数据库在每次出现错误或关机重启之后SQL Serer都会自动运行带有容错功能的特性。SQL Serer用事务日志来完成这项任务,它读取每个数据库事务日志的活动部分,并且检查所有自最新的检查点以来发生的事务。检查点就是最近一次从内存中把数据变化永久写入到数据库中的那个时间点,标识所有已经提交的事务并回滚它们,即把它们重新应用于数据库,然后标识所有未提交的事务并回滚,这样保证删除所有未完全写入数据库的未提交事务。这个过程保证了每个数据库逻辑上的一致性。

第13章数据库的备份与还原 13.4数据库还原操作 13.4.1手动还原 手动还原数据库需要指定数据库还原工作的应用程序和接下来的按照创建顺序排列的事务日志的应用程序。完成这些之后,数据库就会处于和事务日志最后一次备份时一致的状态。 如果使用完全数据库备份来还原,SQL Serer重新创建这些数据库文件和所有的数据库对象;如果使用差异数据库备份来还原,则可以还原最近的差异数据库备份。

第13章数据库的备份与还原 13.4.1手动还原 1. 在SQL Server Management Studio中使用界面还原数据库 (1)在对象资源管理器中展开教学库数据库。 (2)鼠标右击教学库,在弹出的快捷菜单中选择“任务”子菜单,然后选择“还原”-“数据库”命令,弹出“还原数据库-教学库”窗口。 (3) 选择要还原的目标数据库为“教学库”,选择用于还原的备份集为“教学库的完整备份”。

第13章数据库的备份与还原 13.4.1手动还原 1. 在SQL Server Management Studio中使用界面还原数据库 (4) 选择左边的“选项”选项,在“还原选项”中选择“覆盖现有数据库”复选框;在“将数据库文件还原为”中查看或修改“原始文件名”和“还原为”中的文件名,此处都为“教学库”的相应文件;在“恢复状态”选项区域中,选择需要的选项,此处为默认的第一项。 (5)单击“确定”按钮,数据库还原操作完成。打开“教学库”,可以看到其中的数据进行了还原。看不到其中的“Table”表,因为只进行了完整数据库备份的还原。

第13章数据库的备份与还原 13.4.1手动还原 [例13-5]在对象资源管理器中利用教学库的差异数据库备份还原教学库,操作步骤和还原完整数据库备份基本相同。 在“还原数据库-教学库”窗口,选择用于还原的备份集为“教学库的差异备份”,“数据库完整备份”会自动被选中,因为在还原差异备份之前,必须先还原其基准备份。还原操作完成后,打开“教学库”,可以看到完整备份时的数据,也可以看到其中的“Table”表,因为还原了完整数据库备份后的差异数据库备份。

第13章数据库的备份与还原 13.4.1手动还原 2.使用T-SQL语句还原数据库 RESTORE DATABASE { database_name | @database_name_var } [ FROM <backup_device> [ ,...n ] ] [ WITH [ [ , ] FILE = { backup_set_file_number | @backup_set_file_number } ] [ [ , ] KEEP_REPLICATION ] [ [ , ] MEDIANAME = { media_name | @media_name_variable } ] [ [ , ] MEDIAPASSWORD = { mediapassword | @mediapassword_variable } ] [ [ , ] MOVE 'logical_file_name_in_backup' TO 'operating_system_file_name' ] [ ,...n ] [ [ , ] PASSWORD = { password | @password_variable } ] [ [ , ] { RECOVERY | NORECOVERY | STANDBY = {standby_file_name | @standby_file_name_var } } ] [ [ , ] REPLACE ] ]

第13章数据库的备份与还原 13.4.1手动还原 2.使用T-SQL语句还原数据库 RESTORE DATABASE { database_name | @database_name_var } [ FROM <backup_device> [ ,...n ] ] [ WITH [ [ , ] FILE = { backup_set_file_number | @backup_set_file_number } ] [ [ , ] KEEP_REPLICATION ] [ [ , ] MEDIANAME = { media_name | @media_name_variable } ] [ [ , ] MEDIAPASSWORD = { mediapassword | @mediapassword_variable } ] [ [ , ] MOVE 'logical_file_name_in_backup' TO 'operating_system_file_name' ] [ ,...n ] [ [ , ] PASSWORD = { password | @password_variable } ] [ [ , ] { RECOVERY | NORECOVERY | STANDBY = {standby_file_name | @standby_file_name_var } } ] [ [ , ] REPLACE ] ]

第13章数据库的备份与还原 13.4.1手动还原 2.使用T-SQL语句还原数据库 (l) KEEP_REPLICATION:将复制设置为与日志传送一同使用。设置该参数后,在备用服务器上还原数据库时,可防止删除复制设置。 (2)MOVE:将逻辑名指定的数据文件或日志文件还原到所指定的位置。 (3) RECOVERY:回滚未提交的事务,使数据库处于可以使用状态。无法还原其他事务日志。 (4)NORECOVERY:不对数据库执行任何操作,不回滚未提交的事务。可以还原其他事务日志。 (5)STANDBY:使数据库处于只读模式。撤消未提交的事务,但将撤消操作保存在备用文件中,以便可以恢复效果逆转。 (6) standby_file_name | @standby_file_name_var:指定一个允许撤消恢复效果的备用文件或变量。 (7) REPLACE:会覆盖所有现有数据库以及相关文件,包括已存在的同名的其他数据库或文件。

第13章数据库的备份与还原 13.4.1手动还原 [例13-6]将“教学库”数据库的完整数据库备份进行还原。 RESTORE DATABASE教学库 FROM DISK = 'F:\DATA\BACKUP\教学库.Bak' [例13-7]将“教学库”数据库的差异数据库备份进行还原。 FROM DISK = 'F:\DATA\BACKUP\教学库差异备份.Bak' RECOVERY

第13章数据库的备份与还原 13.5数据库分离与附加 SQL Server 2005允许分离数据库的数据和事务日志文件,然后将其重新附加到同一台或另一台服务器上。分离数据库将从 SQL Server 删除数据库,但是保证在组成该数据库的数据和事务日志文件中的数据库完好无损。然后这些数据和事务日志文件可以用来将数据库附加到任何 SQL Server 实例上,这使数据库的使用状态与它分离时的状态完全相同。 例如,如果您数据库系统安装在系统盘(比如C盘),由于C盘容易受病毒侵害,您也许希望您的数据存放在非系统盘(比如D盘),要做的这点很简单,您并不需要重装数据库,只要把数据“分离”,然后将相关文件移动到D盘的某个目录,接着“附加”数据库即可。

第13章数据库的备份与还原 13.5.1分离数据库 1. 在SQL Server Management Studio中使用界面分离数据库 (1)在对象资源管理器中展开要分离的数据库。 (2)鼠标右击数据库名称,在弹出的快捷菜单中选择“任务”子菜单,然后选择“分离”命令。 (3)弹出“分离数据库”对话框。单击“确定”按钮即可完成数据库的分离。

第13章数据库的备份与还原 13.5.1分离数据库 2.使用T-SQL语句分离数据库 可以使用系统存储过程sp_detach_db分离该数据库。sp_detach_db存储过程从服务器分离数据库,并可以选择在分离前在所有的表上运行 UPDATE STATISTICS。 其语法格式如下: sp_detach_db [ @dbname = ] 'dbname' [ , [ @skipchecks = ] 'skipchecks' ]

第13章数据库的备份与还原 13.5.1分离数据库 2.使用T-SQL语句分离数据库 参数说明: (1)[@dbname =] 'dbname':要分离的数据库名称。@dbname 的数据类型为 sysname,默认值为 NULL。 (2)[@skipchecks =] 'skipchecks':@skipchecks 的数据类型为 nvarchar(10),默认值为 NULL。如果为 true,则跳过 UPDATE STATISTICS。如果为 false,则运行 UPDATE STATISTICS。对于要移动到只读媒体上的数据库,此选项很有用。 [例13-8] 分离仓库库存数据库,并将 skipchecks 设为 true。 EXEC sp_detach_db '仓库库存', 'true'

第13章数据库的备份与还原 13.5.2附加数据库 与分离对应的是附加数据库操作。附加数据库可以很方便地在SQL Server 2005服务器之间利用分离后的数据文件和日志文件组织成新的数据库。数据库的附加好比是将衣服(数据库)重新挂上衣架(SQL Server 2005服务器)。 在Microsoft SQL Server 2005中,数据库附加操作有两种方式:在SQL Server Management Studio中使用界面附加数据库和使用T-SQL语句附加数据库。

第13章数据库的备份与还原 13.5.2附加数据库 2.使用T-SQL语句附加数据库 可以使用系统存储过程sp_attach_db将数据库附加到当前服务器或使用系统存储过程sp_attach_single_file_db将只有一个数据文件的数据库附加到当前服务器。 (1) 系统存储过程sp_attach_db附加数据库语法格式: sp_attach_db [ @dbname = ] 'dbname' , [ @filename1 = ] 'filename_n' [ ,...16 ] 参数说明: (1)[@dbname =] 'dbname':要附加到服务器的数据库的名称。该名称必须是唯一的。dbname 的数据类型为 sysname,默认值为 NULL。

第13章数据库的备份与还原 13.5.2附加数据库 2.使用T-SQL语句附加数据库 (2)[@filename1 =] 'filename_n':数据库文件的物理名称,包括路径。filename_n 的数据类型为nvarchar(260),默认值为 NULL。最多可以指定 16 个文件名。参数名称以 @filename1 开始,递增到 @filename16。文件名列表至少必须包括主文件,主文件包含指向数据库中其它文件的系统表。该列表还必须包括数据库分离后所有被移动的文件。 [例13-9] 附加仓库库存数据库到当前服务器。 EXEC sp_attach_db @dbname = '仓库库存', @filename1 = 'F:\DATA\仓库库存.mdf', @filename2 = 'F:\DATA\仓库库存_log.ldf'

第13章数据库的备份与还原 13.5.2附加数据库 2.使用T-SQL语句附加数据库 (2) 系统存储过程sp_attach_single_file_db附加只有一个数据文件的数据库的语法格式: sp_attach_single_file_db [ @dbname = ] 'dbname' , [ @physname = ] 'physical_name' 其中,[@physname =] 'phsyical_name'为据库文件的物理名称,包括路径。physical_name 的数据类型为 nvarchar(260),默认值为 NULL。 [例13-10] 附加仓库库存数据库到当前服务器。 EXEC sp_attach_single_file_db @dbname = '仓库库存', @physname ='F:\DATA\仓库库存.mdf'