`
buliedian
  • 浏览: 1279351 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

关于SQL Server事务日志的问题汇总

阅读更多

1、用BACKUP LOG database WITH NO_LOG清除日志
把数据库属性中的故障还原模型改为“简单”可以大大减慢日志增长的速度。
如果把还原模型调到简单,这样就不支持时间点还原了,但是日志文件会很小,如果数据比较重要
推荐还是把数据库的还原模型调为完全

用BACKUP LOG database WITH NO_LOG命名后,会截断不活动日志,不减小物理日志文件的大小,
但逻辑日志会减小,收缩数据库后会把不活动虚拟日志删除来释放空间,不会损坏数据。

如果日志被截断并收缩数据库后,就不能直接用最近的一个全库备份做时间点还原,建议立即备份
数据库,以防万一。

2、sql server运行中,是否能删除主数据库事务日志文件
步骤如下:(1)、分离数据库
企业管理器--数据库--右击你要删除日志的数据库--所有任务--分离数据库
(2)、然后删除日志文件
(3)、然后再附加数据库
企业管理器--数据库--右击数据库--所有任务--附加数据库
这时候只附加。mdf就可以了。

3、压缩SQL数据库及日志的详细方法

SQL Server 2000基础教程——压缩数据库
数据库在使用一段时间后,时常会出现因数据删除而造成数据库中空闲空间太多的情况,这时就需要减少分配给数据库文件和事务日志文件的磁盘空间,以免浪费磁盘空间。当数据库中没有数据时,可以修改数据库文件属性直接改变其占用空间,但当数据库中有数据时,这样做会破坏数据库中的数据,因此需要使用压缩的方式来缩减数据库空间。可以在数据库属性选项中选择“Auto shrink”选项,让系统自动压缩数据库,也可以用人工的方法来压缩。人工压缩数据库有以下两种方式:
1、用Enterprise Manager 压缩数据库
在Enterprise Manager 中在所要压缩的数据库上单击右键,从快捷菜单中的“所有任务(All Tasks)”中选择“Shrink Database(压缩数据库)”选项,就会出现如图6-10 所示的对话框。可以在图6-10 所示的对话框中选择数据库的压缩方式,也可以选择使用压缩计划或压缩单个文件

单击图6-10 中的“Files”按钮,会出现如图6-11 所示的压缩数据库文件对话框,可以针对每个数据库文件进行不同的压缩设置。

单击图6-10 中的“Change” 按钮,会出现如图6-12 所示的压缩计划编辑对话框,可以指定压缩计划的执行方式。单击图6-12 中的“Change” 按钮,会出现如图6-13 所示的循环工作计划编辑对话框,可以编辑计划执行的周期或时间点。设置完成后单击“OK” 按钮就开始压缩数据库,在压缩结束后会显示一个压缩情况信息框。


2、用Transact-SQL 命令压缩数据库
可以使用DBCC SHRINKDATABASE 和DBCC SHRINKFILE 命令来压缩数据库。其中DBCC SHRINKDATABASE 命令对数据库进行压缩,DBCC SHRINKFILE 命令对数据库中指定的文件进行压缩。
(1) DBCC SHRINKDATABASE
DBCC SHRINKDATABASE 命令语法如下:
DBCC SHRINKDATABASE (database_name [, target_percent]
[, {NOTRUNCATE | TRUNCATEONLY}] )
各参数说明如下:
·target_percent 指定将数据库压缩后,未使用的空间占数据库大小的百分之几。如果指定的百分比过大,超过了压缩前未使用空间所占的比例,则数据库不会被压缩。并且压缩后的数据库不能比数据库初始设定的容量小。
·NOTRUECATE
将数据库缩减后剩余的空间保留在数据库,中不返还给操作系统。如果不选择此选项,则剩余的空间返还给操作系统。
·TRUNCATEONLY
将数据库缩减后剩余的空间返还给操作系统。使用此命令时SQL Server 将文件缩减到最后一个文件分配,区域但不移动任何数据文件。选择此项后,target_percent 选项就无效了。
例6-14: 压缩数据库mytest 的未使用空间为数据库大小的20%。
dbcc shrinkdatabase (mytest, 20)
运行结果如下:
DBCC execution completed. If DBCC printed error messages, contact your system administrator.
(2) DBCC SHRINKFILE
DBCC SHRINKFILE 命令压缩当前数据库中的文件。其语法如下:
DBCC SHRINKFILE ( {file_name | file_id }
{ [, target_size] |
[, {EMPTYFILE | NOTRUNCATE | TRUNCATEONLY}] } )
各参数说明如下:
·file_id
指定要压缩的文件的鉴别号(Identification number, 即ID)。文件的ID 号可以通过 FILE_ID()函数或如本章前面所讲述的Sp_helpdb 系统存储过程来得到。
·target_size
指定文件压缩后的大小。以MB 为单位。如果不指定此选项,SQL Server 就会尽最大可能地缩减文件。
·EMPTYFILE
指明此文件不再使用,将移动所有在此文件中的数据到同一文件组中的其它文件中去。执行带此参数的命令后,此文件就可以用ALTER DATABASE 命令来删除了。
其余参数NOTRUNCATE 和TRUNCATEONLY 与DBCC SHRINKDATABASE 命令中的含义相同。
例6-15: 压缩数据库mydb 中的数据库文件mydb_data2 的大小到1MB。 use mydb dbcc shrinkfile (mydb_data2, 1)


企业管理器里面的方法:
1、打开企业管理器
2、打开要处理的数据库
3、点击最上面菜单>工具>SQL查询分析器,打开SQL查询分析器
4、在输入窗口里面输入:

Code:
DUMP TRANSACTION [数据库名] WITH NO_LOG
BACKUP LOG [数据库名] WITH NO_LOG
DBCC SHRINKDATABASE([数据库名])


点击绿色的小三角(或按F5)执行查询,等状态栏提示处理完成即可!


程序里面的方法:
压缩数据库日志
--1.清空日志
exec('DUMP TRANSACTION ['+@dbname+'] WITH NO_LOG')
--2.截断事务日志:
exec('BACKUP LOG ['+@dbname+'] WITH NO_LOG')
--3.收缩数据库文件(如果不压缩,数据库的文件不会减小
exec('DBCC SHRINKDATABASE(['+@dbname+'])')


4、减小日志的方法:

一、用如下步做了:
1、DUMP TRANSACTION 庫名 WITH no_log
2、dbcc shrinkfile(logfilename)
3、收縮數據庫
4、設定自動收縮。

二、
分离数据库,删除日志文件,再附加,OK!
右击数据库--所有任务--分离or 附加

三、

1、backup log 庫名 WITH no_log
2、dbcc shrinkfile(logfilename)
3、收縮數據庫
4、設定自動收縮。

分享到:
评论

相关推荐

    关于SQLServer事务日志的问题汇总

    关于SQL Server事务日志的问题汇总,本文将深入探讨在处理SQL Server数据库时,与事务日志相关的常见问题及其解决方案。事务日志是SQL Server数据库的关键组成部分,用于记录所有数据更改,确保数据的一致性和完整性...

    sqlserver还原备份数据库以及清理日志文件

    - 在 Windows 文件浏览器中,定位到事务日志文件所在的目录(通常位于 SQL Server 安装目录下的 DATA 文件夹内)。 - 找到与目标数据库对应的 _log.ldf 文件,将其删除。 3. **重新附加数据库** - 使用 SSMS 重新...

    sql server数据库日志满的处理方法

    在IT领域,尤其是在数据库管理与维护中,SQL Server数据库日志满的问题是常见的技术挑战之一。这不仅影响数据库性能,还可能导致数据写入失败、事务处理中断等严重后果。因此,掌握有效的处理方法至关重要。根据给定...

    浅谈SQL Server中的事务日志(二)----事务日志在修改数据时的角色 .docx

    ### SQL Server中的事务日志详解——事务日志在修改数据时的角色 #### 一、引言 事务日志是SQL Server的重要组成部分,它确保了事务处理的持久性(Durability)与事务回滚(Rollback),是实现事务的ACID(原子性...

    SQLServer日志收缩工具

    这个"SQLServer日志收缩工具"很可能是一个名为"trunc.exe"的命令行应用程序,用于简化日志收缩过程。使用这样的工具,用户可以通过简单的命令或者配置来执行日志收缩,无需深入了解SQL Server的T-SQL语句。它可能会...

    Sql Server 日志清理工具 v2.0

    3. **多日志文件支持**:不同于一些只能处理单一日志文件的工具,"Sql Server 日志清理工具 v2.0"能够处理具有多个日志文件的SQLSERVER数据库,这使得它在应对复杂环境下的数据库管理更具优势。 4. **易用性**:...

    SQLServer事务与锁的基础概念总结

    SQLServer事务与锁的基础概念总结 - 小麦的日志 - 网易博客.mht

    SQL Server 2000 清理日志

    这会改变数据库的恢复模型,使得系统不再保留事务日志的完整历史,只保留必要的信息以进行简单恢复。 3. 接下来,再次右键点击该数据库,选择“所有任务” -> “收缩数据库”。在收缩文件对话框中,保持默认设置,...

    SQL_Server_2008删除或压缩数据库日志的方法.doc

    这一步是必要的,因为在简单恢复模式下,SQL Server允许直接截断事务日志,从而达到清理和压缩的目的。 2. **执行日志清理**:在数据库处于简单恢复模式下,可以使用`DBCC SHRINKFILE`命令来压缩日志文件。此外,还...

    SQL Server日志文件总结及充满处理方式

    ### SQL Server日志文件总结及充满处理方式 #### 一、SQL Server交易日志概述 在SQL Server中,交易日志(Transaction Logs)是数据库管理中不可或缺的一部分,它记录了所有针对数据库的操作变化,包括但不限于增删...

    SQL Server日志恢复工具

    SQL Server数据库采用事务日志来跟踪所有对数据库的更改。日志由一系列的事务记录组成,每个记录包含了一个事务的所有操作。数据库引擎提供了三种日志恢复模式:简单恢复模式、完整恢复模式和大容量日志恢复模式。...

    SQL server2000事务日志文件深入剖析.pdf

    总结来说,SQL Server事务日志文件管理是数据库管理和维护中不可忽视的环节。理解事务日志的工作原理,掌握相关命令的使用技巧,配合有效的备份和恢复策略,以及考虑硬件配置的优化,共同构成了确保数据库安全、高效...

    sql server优化事务处理

    SQL Server的事务处理是...总结来说,SQL Server事务优化主要涉及事务的管理、隔离级别选择、锁的控制、数据量的减少以及避免不必要的资源占用。通过这些策略,可以提升数据库性能,减少并发问题,同时保持数据一致性。

    sqlserver中查找长时间未提交事务[总结].pdf

    同时,对事务日志进行备份也只会截断不活动事务的那部分事务日志,所以打开的事务会导致日志变多(甚至达到物理限制),直到事务被提交或回滚。 要找到最早的活动事务,可以使用 DBCC OPENTRAN 命令。DBCC OPENTRAN...

    SQL server Native Client 10.0

    总结来说,SQL Server Native Client 10.0是64位环境下的重要组件,为开发者和系统管理员提供了稳定、高效的连接SQL Server的途径,尤其是在使用SQL Server 2008 R2及其新特性的场景下。通过ODBC和OLE DB接口,它...

    sql server数据库日志压缩

    总结来说,SQL Server数据库日志压缩是一项重要的维护任务,涉及到数据库的性能和可用性。通过理解日志的工作原理,定期执行备份,调整日志文件大小和自动增长策略,以及合理使用收缩和分离功能,可以有效地管理日志...

    SQLServer7指南(下)

    《SQLServer7指南(下)》是一份专为SQL Server 7.0用户设计的详尽教程,旨在帮助用户深入理解和掌握这一版本的数据库管理系统。SQL Server 7.0是微软发布的一个重要的数据库产品,虽然现在已经较为老旧,但对于理解...

    LogExplorer4.2 For sql server使用教程

    **Log Explorer**是一款专用于Microsoft SQL Server事务分析和数据恢复的强大工具。这款工具可以帮助用户浏览数据库日志文件、导出数据以及恢复被修改或删除的数据。尤其在面对系统故障或人为错误导致的数据丢失情况...

    Lumigent Log Explorer for SQL Server

    Lumigent Log Explorer的核心功能在于其对SQL Server事务日志的深入解析。SQL Server的事务日志记录了所有数据库的更改操作,包括插入、更新和删除等,而Lumigent Log Explorer能够解析这些日志,找出并恢复特定的...

    SQL server日志收缩工具

    总结来说,SQL Server日志收缩工具是数据库管理员管理SQL Server环境的重要工具,它可以帮助控制日志文件的大小,释放磁盘空间,同时保持系统的稳定性和高效运行。正确理解和使用这个工具,对于优化SQL Server数据库...

Global site tag (gtag.js) - Google Analytics