SQL Server 2005 数据库快照(database Snapshot)

SQL Server 2005 数据库快照(database Snapshot)

数据库快照(atabase snapshot)是一个只读的,静态的数据库视图。一个数据库可以有多个数据库快照,每个数据库快照在被显性的删除之前将一直存在。数据库快照将保持和源数据库快照被创建时刻一致,所以可被用来做一些报表。并且由于数据库快照的存在,我们可以很容易的把数据库回复到快照创建时刻。

数据库快照提供了一个把数据库回复到一个特定时间点的有效途径。一个数据库快照将记录从这个数据库快照被创建后已经提交的所有事务,这样你在对数据库进行错误操作后也不会发出如果上天能够再给我一次机会的话,我。。。。。。的感慨。由于是只记录数据库发生的改变,也不是在当前的那一时刻数据库的状态,所以数据库文件并不会很大,如下例:

--我们先来为数据库Northwind创建一个数据库快照,命名为NORTHWIND_DBSS1200,并让此数据库快照的文件存储在C:/NORTHWIND_DATA_1200.SS文件中

CREATE DATABASE NORTHWIND_DBSS1200 ON

( NAME = NORTHWIND, FILENAME =

'C:/NORTHWIND_DATA_1200.SS' )

AS SNAPSHOT OF NORTHWIND;

GO

 

--可以看到这个数据库快照文件的属性,如下:可以看到现在Size on disk128K

USE NORTHWIND

GO

--现在Northwind数据库进行更新操作

UPDATE DBO.CUSTOMERS

SET COMPANYNAME='NEWEGG.COM'

--可以看到现在Size on disk384K

--看一下Northwind数据库中被更新的列中存储的内容是已经被更新过的

SELECT DISTINCT  COMPANYNAME FROM NORTHWIND.DBO.CUSTOMERS

 

-- 看一下 NORTHWIND_DBSS1200 数据库中被更新的列中存储的内容还是被更新以前的内容

SELECT DISTINCT  COMPANYNAME  FROM NORTHWIND_DBSS1200.DBO.CUSTOMERS

--IF AN ERROR DAMAGES A DATABASE, YOU MAY CHOOSE TO REVERT THE DATABASE TO A DATABASE SNAPSHOT THAT PREDATES THE ERROR. REVERTING OVERWRITES THE ORIGINAL SOURCE DATABASE WITH THE REVERTED DATABASE.

 

RESTORE DATABASE NORTHWIND FROM

DATABASE_SNAPSHOT = 'NORTHWIND_DBSS1200'

GO

--确认

SELECT DISTINCT  COMPANYNAME FROM NORTHWIND.DBO.CUSTOMERS

 

--删除数据库快照

DROP DATABASE NORTHWIND_DBSS1200

从数据库快照中恢复数据库到快照创建的时刻

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值