SQL Server 数据库日志文件太大的解决办法

SQL数据库日志文件满而造成SQL数据库无法写入文件时,可用两种方法:

一种方法:清空日志。

1.打开查询分析器,输入命令

DUMP TRANSACTION 数据库名 WITH NO_LOG

2.再打开企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了。

另一种方法有一定的风险性,因为SQL SERVER的日志文件不是即时写入数据库主文件的,如处理不当,会造成数据的损失。

1、分离数据库 企业管理器->服务器->数据库->右键->分离数据库

2、我的电脑中删除LOG文件
3、附加数据库:
    企业管理器--服务器--数据库--右键--附加数据库
    此法将生成新的LOG,大小只有500多K

或用代码: 
1、分离
    EXEC sp_detach_db @DBNname = '数据库名'
2、删除日志文件
3、再附加
 EXEC sp_attach_single_file_db @DBNname = '数据库名',@physname = '数据库文件所在的位置'

例如EXEC sp_attach_single_file_db'student',@physname='D:\database\student.mdf'

如果想以后不让它日志增长得太大,企业管理器--服务器--右键数据库--属性--事务日志--将文件增长限制为xM(x是你允许的最大数据文件大小)

猜你喜欢

转载自jiues.iteye.com/blog/1968715