设为首页 收藏本站
查看: 2089|回复: 0

[经验分享] sql server复灾 你懂了吗?

[复制链接]

尚未签到

发表于 2015-6-27 15:22:47 | 显示全部楼层 |阅读模式

  • 很多时候我们不小心错误delete了一下,或者update一下怎么办,或者直接把数据库删除了,怎么办呢,是不是就一定没有办法呢?下面让我来教大家我现学现卖的两招。
  • 当我们不小心删除表怎么办?
  做之前我们要设置数据库恢复模式:
DSC0000.png
  设置成完整,不要是简单模式。
  首先我们创建一个表:插入几条数据
CREATE DATABASE test1


CREATE TABLE A1

(

ID INT  PRIMARY KEY

)


INSERT INTO dbo.A1 ( ID )

VALUES  ( 0 )

INSERT INTO dbo.A1( ID )

VALUES  ( 2)

INSERT INTO dbo.A1( ID )

VALUES  ( 3)

INSERT INTO dbo.A1 ( ID )

VALUES  ( 4 )

INSERT INTO dbo.A1( ID )

VALUES  ( 5 )

DSC0001.png
  SELECT * FROM dbo.A1
我们现在有五条数据了,我们对数据做一个备份
DSC0002.png
  做任何差异备份,和日志之前,一定要做一个完整备份。
我们再插入一条数据

INSERT INTO dbo.A1

        ( ID )

  VALUES  ( 6)
DSC0003.png
  SELECT * FROM dbo.A1我们看看现在有六条数据了。
  关键来了:不小心
   DSC0004.png
  
  数据删除了,一条也没有了怎么办?
  不要慌赶快备份啊。备份数据之后,我们开始来恢复,记住一定要备份在恢复之前哦。这里要做的是日志备份,做完日志备份再恢复数据。
DSC0005.png
  这里要注意时间,我们要选择恢复时间,也就是在你删除的前一刻,然后我们看看6条数据又回来了。
DSC0006.png
  3.  我们删除表数据可以恢复,万一你把数据库服务down掉,然后删除了数据库文件没了呢?
  先建表插入数据如下:
DSC0007.png
  现在有五条数据,然后完整备份,再插入一条数据。
DSC0008.png
  现在有6条数据,做个日志备份
  再插入一条数据
DSC0009.png
  然后把数据库服务停掉,然后我们把数据库文件移除掉。
DSC00010.png
  然后把数据库文件放到一个新建的文件夹里面去,但是日志文件还在的,如果日志文件也没有了,那就求苍天保佑吧,这也是我们把数据文件和日志文件分开的好处之一。
DSC00011.png
  然后我们再启动服务
DSC00012.png
  这个时候test1数据库在,但是你打开的时候一定会报错的。
  那么恢复之前我们需要做一个日志尾备份,因为数据库不能用,所以我们要用。
  backup log test1 to disk='c:\test1.bak' with no_truncate;
  我们查看一下我们的备份。
  恢复之前要做一下查看。
检查备份完整性

restore verifyonly from disk='c:\test1.bak' ;

查看备份文件数目


restore filelistonly from disk='c:\test1.bak' ;

查看备份记录次数

DSC00013.png

  restore headeronly from disk='c:\test1.bak' ;
  我们会发现这里的备份次数比备份文件夹多了一个记录,这是为什么呢?
  是因为我们做了一个日志尾备份。
  好了我们来恢复数据吧。
DSC00014.png
  然后我们恢复一个数据库test2出来了,然后查询数据
DSC00015.png
  这里我们只有六条数据了,而不是七条数据,有数据丢失了怎么办呢?
  原因在:我们可以看到上面我们后台查出的是三条备份次数,但是结果只有两个备份文件记录,那是不是我们最后的日志尾没有了呢?
  不是的这时候我们要手动备份了
RESTORE DATABASE [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 1,  NORECOVERY, replace

GO

RESTORE LOG [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 2,  NORECOVERY

GO

RESTORE LOG [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 3,  NORECOVERY

GO


注意:

  restore headeronly from disk='c:\test1.bak' ;
DSC00016.png
  上面file=1里的1是和我们查出来的 1 2 3 对应的。
DSC00017.png
  诶,怎么test2还在还原呢?
  哦,原来最后一个是NOrecovery我们改成Recovery
RESTORE DATABASE [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 1,  NORECOVERY, replace

GO

RESTORE LOG [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 2,  NORECOVERY

GO

RESTORE LOG [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 3,  RECOVERY

  GO
  哦,数据回来了,看看有七条了。
DSC00018.png
  看到这里你是否有收获呢?
  最后我们看一份数据
DSC00019.png
  这个数据是不是很有规律啊?
  我们可以看到日志备份databasebackuplsn字段数据都是第一份完整备份的checkpoitlsn的数据。
  如果这个数值对不上,我们自求多福吧,恢复不了了。。。。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-80978-1-1.html 上篇帖子: SQL Server 数据库设计 下篇帖子: SQL Server 合并(删除)分区解惑
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表