关于SQL Server数据库日志已满的解决方法

转载 2011年01月20日 10:11:00

解决方法


日志文件满而造成SQL数据库无法写入文件时,可用两种方法:
一种方法:清空日志。
1.打开查询分析器,输入命令
DUMP TRANSACTION 数据库名 WITH NO_LOG
2.再打开企业管理器--右键你要压缩的数据库--所有任务--收缩数据库--收缩文件--选择日志文件--在收缩方式里选择收缩至XXM,这里会给出一个允许收缩到的最小M数,直接输入这个数,确定就可以了。

另一种方法有一定的风险性,因为SQL SERVER的日志文件不是即时写入数据库主文件的,如处理不当,会造成数据的损失。
1: 删除LOG
分离数据库 企业管理器->服务器->数据库->右键->分离数据库
2:删除LOG文件
附加数据库 企业管理器->服务器->数据库->右键->附加数据库
此法生成新的LOG,大小只有500多K。

注意:建议使用第一种方法。

如果以后,不想要它变大。
SQL2000下使用:
在数据库上点右键->属性->选项->故障恢复-模型-选择-简单模型。
或用SQL语句:
alter database 数据库名 set recovery simple

另外,如上图中数据库属性有两个选项,与事务日志的增长有关:
Truncate log on checkpoint
(此选项用于SQL7.0,SQL 2000中即故障恢复模型选择为简单模型)
当执行CHECKPOINT 命令时如果事务日志文件超过其大小的70% 则将其内容清除在开发数据库时时常将此选项设置为True
Auto shrink
定期对数据库进行检查当数据库文件或日志文件的未用空间超过其大小的25%时,系统将会自动缩减文件使其未用空间等于25% 当文件大小没有超过其建立时的初始大小时不会缩减文件缩减后的文件也必须大于或等于其初始大小对事务日志文件的缩减只有在对其作备份时或将 Truncate log on checkpoint 选项设为True 时才能进行。

注意:一般新建立的数据库默认属性已设好,但碰到意外情况使数据库属性被更改,请用户清空日志后,检查数据库的以上属性,以防事务日志再次充满。

 

数据库 'tempdb' 的事务日志已满。若要查明无法重用日志中的空间的原因

最常的做法: --1.清空日志 DUMP TRANSACTION tempdb WITH NO_LOG --2.截断事务日志: BACKUP LOG tempdb WITH NO_LOG --3.收缩...
  • yenange
  • yenange
  • 2014年02月27日 11:24
  • 11401

sql2008 r2 数据库日志文件已满,无法进行其他操作

1、备份数据库 2、备份日志文件。 USE DATABASENAME; GO -- Truncate the log by changing the database r...
  • chiyueqi
  • chiyueqi
  • 2016年04月01日 14:37
  • 2388

数据库 '***' 的日志已满。请备份该数据库的事务日志以释放一些日志空间的解决办法

数据库 '***' 的日志已满。请备份该数据库的事务日志以释放一些日志空间。 说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信...
  • limshirley
  • limshirley
  • 2017年04月17日 14:18
  • 1832

关于SQL Server数据库日志已满的解决方法

转载自:http://dgcnn.blog.51cto.com/124312/78773 事务日志文件Transaction Log File是用来记录数据库更新情况的文件,扩展名为ldf。 在 ...
  • gsyt_2000
  • gsyt_2000
  • 2012年02月04日 09:49
  • 793

SQL Server数据库日志已满的解决方法

日志文件满而造成SQL数据库无法写入文件时,可用两种方法: 一种方法:清空日志。 1.打开查询分析器,输入命令 DUMP TRANSACTION 数据库名 WITH NO_LOG 2.再打开企...
  • jingxuewang110
  • jingxuewang110
  • 2011年09月20日 16:30
  • 867

SQL SERVER 日志已满的问题解决方法

事务日志文件Transaction Log File是用来记录数据库更新情况的文件,扩展名为ldf。 在 SQL Server 7.0 和 SQL Server 2000 中,如果设置了自动增长功能...
  • regedit1987
  • regedit1987
  • 2013年12月04日 09:51
  • 482

SQL SERVER 日志已满的处理方法

原文: 点击打开链接 事务日志文件Transaction Log File是用来记录数据库更新情况的文件,扩展名为ldf。 在 SQL Server 7.0 和 SQL Serve...
  • yenange
  • yenange
  • 2014年04月02日 12:58
  • 705

SQL SERVER 日志已满的处理方法

事务日志文件Transaction Log File是用来记录数据库更新情况的文件,扩展名为ldf。 在 SQL Server 7.0 和 SQL Server 2000 中,如果设置了自动增长功能...
  • wzsy
  • wzsy
  • 2013年06月08日 10:41
  • 482

SQL SERVER 日志已满的处理方法 (转)

事务日志文件Transaction Log File是用来记录数据库更新情况的文件,扩展名为ldf。 在 SQL Server 7.0 和 SQL Server 2000 中,如果设置了自动增长功能...
  • skjack2010
  • skjack2010
  • 2013年11月28日 11:00
  • 377

SQL SERVER 日志已满的处理方法

事务日志文件Transaction Log File是用来记录数据库更新情况的文件,扩展名为ldf。 在 SQL Server 7.0 和 SQL Server 2000 中,如果设置了自动增长功能...
  • Mevin
  • Mevin
  • 2012年07月11日 11:16
  • 698
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于SQL Server数据库日志已满的解决方法
举报原因:
原因补充:

(最多只允许输入30个字)