下面,容我来向大家介绍数据库学习内容,主要讲述的是SQL Server 2008高可用性系列之数据库快照。想了解的就来看看吧!

一:简介:数据库快照是一个数据库的只读副本,它是数据库所有数据的映射,由快照被执行的时间点来决定它的内容。这些数据库快照在报表方面是非常有价值,因为在快照数据库中或者在原数据库中,对于任何查询而言没有锁就将被执行。快照也可以使用在灾难恢复中,因为你可以将现有的数据恢复到现有的快照中,或者还可以在有害数据操作声明的事件中存储个别必要的表和数据。

快照可用于报表。另外,如果源数据库出现用户错误,还可将源数据库恢复到创建快照时的状态。丢失的数据仅限于创建快照后数据库更新的数据。

运行原理: 数据库快照在数据页级运行。在第一次修改源数据库页之前,先将原始页从源数据库复制到快照。此过程称为“写入时复制操作”。快照将存储原始页,保留它们在创建快照时的数据记录。对已修改页中的记录进行后续更新不会影响快照的内容。对要进行第一次修改的每一页重复此过程。这样,快照将保留自创建快照后经修改的所有数据记录的原始页。

注:只有SQL Server 2005EntERPrise Edition 和更高版本才提供数据库快照功能,所有恢复模式都支持数据库快照。

二:数据库快照的典型用法及工作方式

1. 数据库快照的典型用法:

维护历史数据以生成报表。

使用为了实现可用性目标而维护的镜像数据库来减轻报表负载。

使数据免受管理失误所带来的影响。

在进行重大更新(例如,大容量更新或架构更改)之前,可创建数据库快照以保护数据。一旦进行了错误操作,可以使用快照将数据库恢复到生成快照时的状态。

使数据免受用户失误所带来的影响。

管理测试数据库

提示:数据库快照与源数据库相关。因此,使用数据库快照还原数据库不能代替备份和还原策略。严格按计划执行备份仍然至关重要。如果必须将源数据库还原到创建数据库快照的时间点,请实施允许您执行该操作的备份策略。

2. 数据库快照的工作方式

了解快照中的稀疏文件:为了存储复制的原始页,快照使用一个或多个“稀疏文件”。最初,稀疏文件实质上是空文件,不包含用户数据并且未被分配存储用户数据的磁盘空间。随着源数据库中更新的页越来越多,文件的大小也不断增长。创建快照时,稀疏文件占用的磁盘空间很少。然而,由于数据库随着时间的推移不断更新,稀疏文件会增长为一个很大的文件。

快照的工作方式:

(1) 写操作

第一次写入时会把原始页页复制到快照。

(2) 读操作

无更新页之前的读过程

有更新页之后的读过程,可以看到快照读取的是创建快照时的那一页。

(3) 较多的读写之后

随着源数据库中更新的页越来越多,拷贝到快照中的页页越来越多,文件的大小也不断增长。

快照保存的是数据更新之前的那份拷贝,所以通过快照读取的数据是数据更新之前的那一份,数据丢失就可以恢复到创建快照的这个时间点。

三:应用实例

1. 快照的命名

创建数据库快照之前,考虑如何命名它们是非常重要的。每个数据库快照都需要一个唯一的数据库名称。为了便于管理,数据库快照的名称可以包含标识数据库的信息,例如:

源数据库的名称。

该新名称用于快照的指示信息。

快照的创建日期和时间、序列号或一些其他的信息(例如一天中的某个时间)以区分给定的数据库上的连续快照。

如:

以6个小时为间隔(06:00-18:00之间)创建快照:

AdventureWorks2008_snapshot_0600

AdventureWorks2008_snapshot_1200

AdventureWorks2008_snapshot_1800

或者不太精确的命名:

AdventureWorks2008_snapshot_morning

AdventureWorks2008_snapshot_noon

AdventureWorks2008_snapshot_evening

2. 创建数据库快照

语法示例:

CREATE DATABASE AdventureWorks2008_dbss1800 ON

( NAME = AdventureWorks2008_Data, FILENAME = ‘D:\\DATA\\AdventureWorks2008_data_1800.ss' )

AS SNAPSHOT OF AdventureWorks2008;

.Snapshot Name: AdventureWorks2008_dbss1800

.NAME: source database data file name

.FILENAME: snapshot sparse file name

3. 删掉数据库快照

DROP DATABASE AdventureWorks2008_dbss1800

四:数据库快照的限制

1. 对源数据库的限制

不能对数据库进行删除、分离或还原。

源数据库的性能受到影响。由于每次更新页时都会对快照执行“写入时复制”操作,导致源数据库上的 I/O 增加。

不能从源数据库或任何快照中删除文件。

源数据库必须处于联机状态,除非该数据库在数据库镜像会话中是镜像数据库。

不能将源数据库配置为可缩放共享数据库。

若要在镜像数据库中创建数据库快照,数据库必须处于同步镜像状态。

2. 数据库快照的限制

数据库快照必须与源数据库在相同的服务器实例上创建和保留。

始终对整个数据库拍摄数据库快照。

数据库快照与源数据库相关。因此,使用数据库快照还原数据库不能代替备份和还原策略。严格按计划执行备份仍然至关重要。如果必须将源数据库还原到创建数据库快照的时间点,请实施允许您执行该操作的备份策略。

当将源数据库中更新的页强制压入快照时,如果快照用尽磁盘空间或者遇到其他错误,则该快照将成为可疑快照并且必须将其删除。

快照为只读。

禁止对 model 数据库、master 数据库和 tempdb 数据库创建快照。

不能从数据库快照中删除文件。

不能备份或还原数据库快照。

不能附加或分离数据库快照。

注:更多的限制请参照MSDN。

四:总结

数据库快照只是提供数据恢复的一种方式,在遇到灾难发生时, 数据可以恢复到创建快照的那个时间点。恢复操作可以恢复最近出现的严重用户错误,如删除表等。不能代替完整的备份还原策略。

以上内容就到此结束了,如够你还想了解更多相关的数据库教程,那么,你可以前往课课家官方网,一定会不枉此行的。

创建mysql数据库快照_数据库教程相关推荐

  1. 创建mysql数据库快照_创建数据库快照 (Transact-SQL)

    创建数据库快照 (Transact-SQL)Create a Database Snapshot (Transact-SQL) 08/10/2016 本文内容 适用于:Applies to: SQL ...

  2. MySQL数据库变量_数据库参数_MySQL变量_系统变量_用户变量

    文章目录 MySQL 变量分类 系统变量 查看系统变量 设置系统变量 如何通过配置文件来设置变量值 通过命令行选项来设置变量值 动态设置全局级的系统变量 设置静态的系统变量 设置会话级的系统变量 引用 ...

  3. rds mysql 视图 索引_数据库 视图 索引

    SQL2K数据库开发二十二之索引操作在视图上创建索引 1.在企业管理器中,右击要创建索引的视图,在弹出的菜单中选择"设计视图"命令进入视图设计器. 2.在视图设计器中显示了视图所包 ...

  4. 数据库mysql的索引_数据库索引

    数据库索引 编辑 锁定 索引是对数据库表中一列或多列的值进行排序的一种结构,使用索引可快速访问数据库表中的特定信息.如果想按特定职员的姓来查找他或她,则与在表中搜索所有的行相比,索引有助于更快地获取信 ...

  5. mysql账目表_数据库1(数据库、表及表数据、SQL语句)

    01数据库概念 A: 什么是数据库 数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来, 用户可以对数据库中的数据进行增加,修改,删除及查询操作. B: 什么是数据库管理 ...

  6. mysql sqlite转换_数据库转换工具(SqliteToMysql)

    SqliteToMysql是一款用于SQLITE和MYSQL之间的数据库转换工具.它能够将SQLITE数据转换成MYSQL数据库,让用户自主配置转换条件,满足用户的数据库格式需要.. 相关软件软件大小 ...

  7. java mysql数据库回退_数据库事务及Java中的处理

    事 务是指一组相互依赖的操作行为,举一个举得不能再被举的例子就是银行交易,当然还有其他像网上购物,电子货币交易等等,事务的成功取决于这些相互依赖的操 作行为是否都能执行成功,只要有一个操作行为失败,就 ...

  8. mysql数据转换英文_数据库转换工具下载_SqliteToMysql英文版2.5 - 系统城

    SqliteToMysql是一款专门用来完成数据库数据转换的软件,通过该软件,我们可以将Sqlite数据库和Mysql数据库数据的互相转换,这样你就可以将一些重要的数据快速完成转换和备份,有需要的小伙 ...

  9. mysql数据库算法_数据库:MySQL索引背后的数据结构及算法原理【转】

    原文:http://blog.codinglabs.org/articles/theory-of-mysql-index.html 摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话 ...

最新文章

  1. 常用的排序算法的时间复杂度和空间复杂度
  2. [Android] TableLayout
  3. 函数要多小才够好——谈小函数之道
  4. SQL Server 2008 阻止保存要求重新创建表的更改问题的设置方法
  5. 【OpenCV3】双线性插值
  6. 成功解决Exception unhandled ImportError DLL load failed: 找不到指定的程序。 lib\imp.py, Line: 343
  7. EasyUI中进度条的简单使用
  8. 编写一个猜数字游戏程序:
  9. “手把手教你学linux驱动开发”OK6410系列之01---模块编程
  10. php相册上传和删除吗,php如何删除上传图片
  11. C语言内存的动态分配
  12. ICONV for Windows
  13. Dubbo的架构体系
  14. es6转es5_ES6 配置运行环境
  15. 安全测试工具之-Burpsuite
  16. Mac Eclipse 主题选择
  17. 神州炫龙蓝天刷bios教程(百分百成功/不成功下面留言)
  18. 2014全国计算机等级考试四级数据库工程师考试大纲,全国计算机等级考试四级数据库工程师...
  19. office365彻底卸载教程
  20. 蛋疼菊紧的Outlook 2013

热门文章

  1. Java 导出 Excel 文件
  2. logstash收集java日志,多行合并成一行
  3. Prime Time UVA - 10200
  4. Python 函数 -next()
  5. 【操作系统】多道程序的理解
  6. IntelliJ IDEA中Maven项目的默认JDK版本
  7. Update From 用法
  8. 数据库开发总结(ADO.NET小结)
  9. leetcode 1189 python
  10. MySQL checkpoint机制详解