sql server复灾 你懂了吗?

标签: sql server | 发表时间:2011-06-12 08:34 | 作者:MR_ke brett80
出处:http://www.cnblogs.com/

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

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

 

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

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

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 )

 

SELECT * FROM dbo.A1
我们现在有五条数据了,我们对数据做一个备份

 

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

我们再插入一条数据

INSERT INTO dbo.A1

        ( ID )

VALUES  ( 6)

 

SELECT * FROM dbo.A1我们看看现在有六条数据了。

关键来了:不小心 

 

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

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

 

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

 

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

先建表插入数据如下:

 

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

 

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

再插入一条数据

 

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

 

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

 

然后我们再启动服务

 

这个时候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' ;

查看备份记录次数

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

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

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

好了我们来恢复数据吧。

 

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

 

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

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

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

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' ;

 

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

 

诶,怎么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

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

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

最后我们看一份数据

 

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

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

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

作者: MR_ke 发表于 2011-06-12 16:34 原文链接

评论: 4 查看评论 发表评论


最新新闻:
· 许朝军回应抨击人人是炒作点点:产品最重要(2011-06-12 22:27)
· Google Earth里植入更多的3D树木(2011-06-12 21:45)
· IBM开源Java语言变种NetRexx(2011-06-12 21:42)
· Richard MacManus:20年后,网站将不复存在?(2011-06-12 21:40)
· 亚马逊拒绝缴纳营业税 再次中断在美两州业务(2011-06-12 21:38)

编辑推荐:自己动手开发编译器(四)利用DFA转换表建立扫描器

网站导航:博客园首页  我的园子  新闻  闪存  小组  博问  知识库

相关 [sql server] 推荐:

SQL Server--索引

- - CSDN博客推荐文章
         1,概念:  数据库索引是对数据表中一个或多个列的值进行排序的结构,就像一本书的目录一样,索引提供了在行中快速查询特定行的能力..             2.1优点:  1,大大加快搜索数据的速度,这是引入索引的主要原因..                             2,创建唯一性索引,保证数据库表中每一行数据的唯一性..

SQL Server 面试

- - SQL - 编程语言 - ITeye博客
在SQL语言中,一个SELECT…FROM…WHERE语句称为一个查询块,将一个查询块嵌套在另一个查询块的WHERE子句中的查询称为子查询. 子查询分为嵌套子查询和相关子查询两种. 嵌套子查询的求解方法是由里向外处理,即每个子查询在其上一级查询处理之前求解,子查询的结果作为其父查询的查询条件. 子查询只执行一次,且可以单独执行;.

SQL Server优化50法

- - CSDN博客推荐文章
虽然查询速度慢的原因很多,但是如果通过一定的优化,也可以使查询问题得到一定程度的解决.   查询速度慢的原因很多,常见如下几种:没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷).   I/O吞吐量小,形成了瓶颈效应.   没有创建计算列导致查询不优化.   内存不足网络速度慢查询出的数据量过大(可以采用多次查询,其他的方法降低数据量).

SQL Server 中的事务

- - CSDN博客推荐文章
       事务要有非常明确的开始和结束点,SQL Server 中的每一条数据操作语句,例如SELECT、INSERT、UPDATE和DELETE都是隐式事务的一部分. 即使只有一条语句,系统也会把这条语句当做一个事务,要么执行所有的语句,要么什么都不执行.         事务开始之后,事务所有的操作都会写到事务日志中,写到日志中的事务,一般有两种:一是针对数据的操作,例如插入、修改和删除,这些操作的对象是大量的数据;另一种是针对任务的操作,例如创建索引.

SQL Server优化50法

- - CSDN博客数据库推荐文章
  虽然查询速度慢的原因很多,但是如果通过一定的优化,也可以使查询问题得到一定程度的解决.   查询速度慢的原因很多,常见如下几种:. 没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷). I/O吞吐量小,形成了瓶颈效应. 查询出的数据量过大(可以采用多次查询,其他的方法降低数据量).

SQL Server 查询步骤 - pursuer.chen

- - 博客园_首页
标签:SQL SERVER/MSSQL SERVER/数据库/DBA/查询步骤.       查询步骤是很基础也挺重要的一部分,但是我还是在周围发现有些人虽然会语法,但是对于其中的步骤不是很清楚,这里就来分解一下其中的步骤,在技术内幕系列里面都会有讲到.  TOP于ORDER BY的关系. INSERT INTO Customers VALUES(1,'深圳'),(2,'广州'),(3,'武汉'),(4,'上海'),(5,'北京').

sql server复灾 你懂了吗?

- brett80 - 博客园-首页原创精华区
很多时候我们不小心错误delete了一下,或者update一下怎么办,或者直接把数据库删除了,怎么办呢,是不是就一定没有办法呢. 下面让我来教大家我现学现卖的两招. 做之前我们要设置数据库恢复模式:. 首先我们创建一个表:插入几条数据. 我们现在有五条数据了,我们对数据做一个备份. 做任何差异备份,和日志之前,一定要做一个完整备份.

监控 SQL Server 的运行状况

- Bloger - 博客园-首页原创精华区
Microsoft SQL Server 2005 提供了一些工具来监控数据库. 动态管理视图 (DMV) 和动态管理函数 (DMF) 返回的服务器状态信息可用于监控服务器实例的运行状况、诊断问题和优化性能. 常规服务器动态管理对象包括:. dm_db_*:数据库和数据库对象. dm_exec_*:执行用户代码和关联的连接.

SQL Server 数据库巡检脚本

- - CSDN博客数据库推荐文章
select '现在没有阻塞和死锁信息' as message. select '引起数据库死锁的是: '+ CAST(@bl AS VARCHAR(10)) + '进程号,其执行的SQL语法如下'. select '进程号SPID:'+ CAST(@spid AS VARCHAR(10))+ '被' + '进程号SPID:'+ CAST(@bl AS VARCHAR(10)) +'阻塞,其当前进程执行的SQL语法如下'.

SQL Server分页3种方案比拼

- - CSDN博客推荐文章
插入数据:(2万条,用更多的数据测试会明显一些) . 分页方案一:(利用Not In和SELECT TOP分页) . SELECT TOP 页大小 * .           (SELECT TOP 页大小*页数 id .          FROM 表 . 分页方案二:(利用ID大于多少和SELECT TOP分页) .