`
jeffrey_zhang
  • 浏览: 19382 次
  • 性别: Icon_minigender_1
  • 来自: 南京
最近访客 更多访客>>
社区版块
存档分类
最新评论

sqlserver日志文件太大解决方法<转>

阅读更多

 

SQL Server 的事务日志意外增大或充满的处理方法

事务日志文件Transaction Log File是用来记录数据库更新情况的文件,扩展名为ldf。
在 SQL Server 7.0 和 SQL Server 2000 中,如果设置了自动增长功能,事务日志文件将会自动扩展。
一般情况下,在能够容纳两次事务日志截断之间发生的最大数量的事务时,事务日志的大小是稳定的,事务日志截断由检查点或者事务日志备份触发。
然而,在某些情况下,事务日志可能会变得非常大,以致用尽空间或变满。通常,在事务日志文件占尽可用磁盘空间且不能再扩展时,您将收到如下错误消息:
Error:9002, Severity:17, State:2
The log file for database '%.*ls' is full.
除了出现此错误消息之外,SQL Server 还可能因为缺少事务日志扩展空间而将数据库标记为 SUSPECT。有关如何从此情形中恢复的其他信息,请参见 SQL Server 联机帮助中的“磁盘空间不足”主题。

另外,事务日志扩展可能导致下列情形: 
· 非常大的事务日志文件。 
· 事务可能会失败并可能开始回滚。 
· 事务可能会用很长时间才能完成。 
· 可能发生性能问题。 
· 可能发生阻塞现象。

原因
事务日志扩展可能由于以下原因或情形而发生: 
· 未提交的事务 
· 非常大的事务 
· 操作:DBCC DBREINDEX 和 CREATE INDEX 
· 在从事务日志备份还原时 
· 客户端应用程序不处理所有结果 
· 查询在事务日志完成扩展之前超时,您收到假的“Log Full”错误消息 
· 未复制的事务

解决方法
日志文件满而造成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 时才能进行。


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

 

分享到:
评论

相关推荐

    SQLServer处理事务日志文件过大方法

    ### SQL Server处理事务日志文件过大方法 #### 一、问题背景 在SQL Server数据库管理系统中,事务日志文件(Transaction Log File)是用于记录所有事务更改的关键组件之一。随着数据库活动的增加,特别是当数据库...

    如何解决SQL Server日志满问题

    解决 SQL Server 日志满问题的多种方法 SQL Server 是一种关系数据库管理系统,广泛应用于企业级应用中。但是,随着数据的增长,SQL Server 的日志文件也会不断增长,占用越来越多的磁盘空间。如果不及时处理,日志...

    SQL日志文件太大的清理方法

    SQL日志文件过大是数据库管理中的常见问题,通过上述方法可以有效地管理和控制日志文件的大小,确保数据库的稳定性和性能。在实际操作中,应根据具体情况选择合适的方法,并注意备份数据,避免数据丢失风险。此外,...

    SQL 2008日志收缩 清空删除大日志文件

    在SQL Server 2008中,日志文件的管理和收缩相比SQL Server 2005有所不同,主要是因为SQL Server 2008对数据库的日志处理进行了优化。日志文件(.ldf)主要用于存储数据库事务日志,是确保数据完整性和可恢复性的...

    SQLServer日志文件太大如何解决

    MS SQL清除日志的命令 如何清除sqlserver 日志? 【手工方式】 设置数据库为简单模式,自动收缩 1打开查询分析器输入命令 backup log databasename with no_log 2.再打开企业管理器--右键你要压缩的数据库--...

    SQLServer数据库日志太大收缩操作指南

    本文档提供了一种详细的SQLServer数据库日志太大时的收缩操作指南,旨在帮助管理员有效地管理和减小日志文件的大小。 ### 1. 数据库日志文件过大原因 数据库日志文件过大通常是因为以下原因: 1. **事务回滚**:...

    SQL SERVER Always On收缩日志文件详细操作及问题处理(已亲测通过)

    在SQL SERVER Always On环境下收缩日志文件通常涉及以下步骤: 1. **备份日志**:首先,需要备份事务日志,这可以通过`BACKUP LOG`命令实现。在这个例子中,日志被备份到`NUL:`设备,这意味着日志备份不占用实际...

    SQL2008R2数据库日志太大收缩方法

    SQL2008R2数据库日志太大收缩方法,登陆项目平台数据库服务器。双击SQL Server Management Studio打开数据库管理

    SQL Server日志文件不断增长处理方法

    SQL Server日志文件的增长是数据库管理员常常面临的问题,这主要涉及到SQL Server的日志管理机制以及如何有效处理日志文件的增长。下面将详细解释这一主题。 首先,了解SQL Server需要保存的日志记录至关重要。日志...

    SqlServer日志清除专家

    【SqlServer日志清除专家】是一款专门针对SQL Server数据库的日志清理工具,旨在帮助数据库管理员高效地管理和优化数据库的日志文件。作为一个免安装、绿色版的应用程序,它无需复杂的安装过程,用户可以直接运行...

    Sqlserver2005日志文件太大如何减小

    在SQL Server 2005中,当数据库的日志文件(.ldf)变得过大时,可能会对系统性能和磁盘空间造成负面影响。以下是一些减小SQL Server 2005日志文件大小的方法: 1. **备份日志并截断**: 使用`BACKUP LOG`命令配合`...

    SQLSERVER数据库因日志文件太大,造成写数据慢的解决方法-附件资源

    SQLSERVER数据库因日志文件太大,造成写数据慢的解决方法-附件资源

    Sqlserver大数据量插入速度慢或丢失数据的解决方法

    ### Sqlserver大数据量插入速度慢或丢失数据的解决方法 #### 概述 在处理大量数据插入SQL Server数据库的过程中,可能会遇到插入速度慢或者数据丢失的问题。这种情况通常出现在需要批量插入数千甚至上万条记录的...

    SQL Server 2000 清理日志

    然而,随着数据库活动的增加,日志文件可能会变得非常大,占用大量的磁盘空间,这可能会影响系统性能并导致存储问题。本文将详细介绍如何清理和管理SQL Server 2000的日志。 首先,我们来看看如何通过SQL Server ...

    清理SQL Server日志释放文件空间的方法

    总之,清理SQL Server日志文件释放空间是一个需要谨慎操作的过程,涉及到数据库的恢复模式、日志备份和文件管理等多个方面。正确理解和运用这些知识,可以帮助我们更有效地管理和优化数据库的存储空间。

    SQL2008数据库日志太大收缩方法(1).doc

    针对这种情况,我们可以采取一系列方法来收缩SQL Server 2008数据库的日志文件,以优化存储资源并提高系统效率。以下是一份详细的操作指南: 1. **登录数据库服务器**: 首先,你需要登录到运行SQL Server 2008的...

    SQLServer日志清除专家3.0绿色免费版

    SQLServer日志清除专家是一款专为SQL Server数据库设计的实用工具,主要用于管理和优化数据库的日志文件,以提高系统性能和稳定性。此版本为3.0绿色免费版,无需安装即可直接运行,对于需要定期清理和管理SQL Server...

    数据库日志文件太大的解决方案

    ### 数据库日志文件太大的解决方案 在数据库管理过程中,日志文件的大小是一个非常重要的监控指标。过大的日志文件不仅会占用大量的磁盘空间,还可能导致性能问题,如数据库响应时间增加、备份时间延长等。因此,...

Global site tag (gtag.js) - Google Analytics