数据库修复系列Part4:重建数据库日志文件

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
日志服务 SLS,月写入数据量 50GB 1个月
简介:
+关注继续查看

我们可能会遇到日志文件损坏或者被不小心删除的问题,导致数据库无法访问。在没有备份的情况下,可以用重建日志文件恢复数据库,但是可能会有数据丢失。 另外本篇文件还通过举例证明了日志文件的重要性(许多人说日志文件是可以删除的,这个是完全错误的)。

 1. select * from Test(有两条记录1,2)

查询结果:

idTest

-----------

1

2

 2. 更新一条记录(将1更改为3),但是不提交事务。

 begin tran

update Test set idTest=3where idTest= 1

 

checkpoint

 select * from Test

查询结果:

idTest

-----------

2

3

 (2 row(s) affected)

 3. 关闭SQL Server服务器

 

4. 删掉ldf文件重启Service,并且访问数据库会得到下面的错误:

 Msg 945, Level 14, State 2,Line 2

Database 'FNDBLogTest' cannotbe opened due to inaccessible files or insufficient memory or disk space. See the SQL Server errorlog for details.

 5. 重建日志文件:

 ALTER DATABASE FNDBLogTestREBUILDLOGON(NAME=FNDBLogTest_Log,

FILENAME='D:\ProgramFiles\Microsoft SQL Server\MSSQL10_50.R2\MSSQL\DATA\FNDBLogTest_Log.ldf')

 Warning: The log for database'FNDBLogTest' has been rebuilt. Transactional consistency has been lost.The RESTORE chain was broken, and the server no longer has context on theprevious log files, so you will need to know what they were. You should run DBCCCHECKDB to validate physical consistency. The database has been put in dbo-onlymode. When you are ready to make the database available for use, you will needto reset database options and delete any extra log files.

 6. 查询test表数据:

 select * from Test

 idTest

-----------

2

3

 (2 row(s) affected)

  注意:这里我们看到数据是3而不是1,跟我们期望的数据是不一致的。因为数据库关闭时事务还没有提交,正确的值应该是1.所以SQL Server的日志文件是非常重要的,不能随便删除。 SQL Server是利用日志文件做REDO/UNDO。重建日志只是建造一个正确的日志结构文件但是数据是空的(查看SQL Server事务可以参考我前面的两篇博客

 所以重建日志文件是在没有备份的情况下才会尝试的方法。

 

最后我们还需要运行DBCC CHECKDB检查数据库完整性:

 USE FNDBLogTest

GO

DBCC CHECKDB WITHNO_INFOMSGS


本文转自 lzf328 51CTO博客,原文链接:

http://blog.51cto.com/lzf328/957241
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
关系型数据库 MySQL 数据库
如何修复损坏的MySQL数据表[转]
原文地址:http://www.3v.org.cn/article.asp?id=164 由于断电或非正常关机而导致MySQL数据库出现错误是非常常见的问题。有两种方法,一种方法使用mysql的check table和repair table 的sql语句,另一种方法是使用MySQL提供的多个myisamchk, isamchk数据检测恢复工具。
1789 0
|
SQL Go 数据库
SQL Server日志文件过大 大日志文件清理方法 不分离数据库
原文:SQL Server日志文件过大 大日志文件清理方法 不分离数据库 SQL Server日志文件过大    大日志文件清理方法 ,网上提供了很多分离数据库——〉删除日志文件-〉附加数据库 的方法,此方法风险太大,过程也比较久,有时候也会出现分离不成功的现象。
2566 0
|
Oracle 关系型数据库 数据库
推荐文章
更多