SQL Server复灾 你懂了吗?

1.很多时候我们不小心错误delete了一下,或者update一下怎么办,或者直接把数据库删除了,怎么办呢,是不是就一定没有办法呢?下面让我来教大家我现学现卖的两招。

2.当我们不小心删除表怎么办?

做之前我们要设置数据库恢复模式:

 

设置成完整,不要是简单模式。

首先我们创建一个表:插入几条数据

  1. CREATE DATABASE test1  
  2. CREATE TABLE A1  
  3. (  
  4. ID INT  PRIMARY KEY 
  5. )  
  6. INSERT INTO dbo.A1 ( ID )  
  7. VALUES  ( 0 )  
  8. INSERT INTO dbo.A1( ID )  
  9. VALUES  ( 2)  
  10. INSERT INTO dbo.A1( ID )  
  11. VALUES  ( 3)  
  12. INSERT INTO dbo.A1 ( ID )  
  13. VALUES  ( 4 )  
  14. INSERT INTO dbo.A1( ID )  
  15. VALUES  ( 5 )  

 

  1. SELECT * FROM dbo.A1  

我们现在有五条数据了,我们对数据做一个备份

做任何差异备份,和日志之前,一定要做一个完整备份。

我们再插入一条数据

  1. INSERT INTO dbo.A1  
  2.         ( ID )  
  3. VALUES  ( 6)  

 

  1. SELECT * FROM dbo.A1 

我们看看现在有六条数据了。

关键来了:不小心

 

数据删除了,一条也没有了怎么办?

不要慌赶快备份啊。备份数据之后,我们开始来恢复,记住一定要备份在恢复之前哦。这里要做的是日志备份,做完日志备份再恢复数据。

 

这里要注意时间,我们要选择恢复时间,也就是在你删除的前一刻,然后我们看看6条数据又回来了。

 

3.  我们删除表数据可以恢复,万一你把数据库服务down掉,然后删除了数据库文件没了呢?

先建表插入数据如下:

现在有五条数据,然后完整备份,再插入一条数据。

 

现在有6条数据,做个日志备份

#p#

再插入一条数据

 

然后把数据库服务停掉,然后我们把数据库文件移除掉。

 

然后把数据库文件放到一个新建的文件夹里面去,但是日志文件还在的,如果日志文件也没有了,那就求苍天保佑吧,这也是我们把数据文件和日志文件分开的好处之一。

 

然后我们再启动服务

 

这个时候test1数据库在,但是你打开的时候一定会报错的。

那么恢复之前我们需要做一个日志尾备份,因为数据库不能用,所以我们要用。

  1. backup log test1 to disk='c:\test1.bak' with no_truncate; 

我们查看一下我们的备份。

恢复之前要做一下查看。

检查备份完整性

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

查看备份文件数目

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

查看备份记录次数

 

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

我们会发现这里的备份次数比备份文件夹多了一个记录,这是为什么呢?

是因为我们做了一个日志尾备份。

好了我们来恢复数据吧。

 

然后我们恢复一个数据库test2出来了,然后查询数据

 

这里我们只有六条数据了,而不是七条数据,有数据丢失了怎么办呢?

原因在:我们可以看到上面我们后台查出的是三条备份次数,但是结果只有两个备份文件记录,那是不是我们***的日志尾没有了呢?

不是的这时候我们要手动备份了

  1. RESTORE DATABASE [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 1,  NORECOVERY, replace 
  2. GO  
  3. RESTORE LOG [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 2,  NORECOVERY  
  4. GO  
  5. RESTORE LOG [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 3,  NORECOVERY  
  6. GO  

注意:

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

上面file=1里的1是和我们查出来的 1 2 3 对应的。

 

诶,怎么test2还在还原呢?

哦,原来***一个是NOrecovery我们改成Recovery

  1. RESTORE DATABASE [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 1,  NORECOVERY, replace 
  2. GO  
  3. RESTORE LOG [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 2,  NORECOVERY  
  4. GO  
  5. RESTORE LOG [test2] FROM  DISK = N'C:\test1.bak' WITH  FILE = 3,  RECOVERY  
  6. GO 

哦,数据回来了,看看有七条了。

看到这里你是否有收获呢?

***我们看一份数据

 

这个数据是不是很有规律啊?

我们可以看到日志备份databasebackuplsn字段数据都是***份完整备份的checkpoitlsn的数据。

如果这个数值对不上,我们自求多福吧,恢复不了了。。。。

有错误的地方欢迎大家拍砖,希望交流和共享。

原文链接:http://www.cnblogs.com/MR_ke/archive/2011/06/12/2078927.html

【编辑推荐】

 

  1. SQL Server管理 这些你懂吗?
  2. 淘宝海量数据库之克服随机IO难题
  3. 数据库如何抵抗随机IO的问题、方法与现实
  4. 用一句SQL解决SQL中断号问题
  5. 养成一个SQL好习惯带来一笔大财富

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/267128.html<

(0)
运维的头像运维
上一篇2025-05-06 06:51
下一篇 2025-05-06 06:52

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注