在 Microsoft® SQL Server™ 2000 中,可以在用户使用数据库时运行 DBCC CHECKDB,因为 DBCC CHECKDB 在检查每个数据库表时在表上控制的锁的类型均更改。
在 SQL Server 7.0 和早期版本中,DBCC CHECKDB(依次在数据库的每个表上运行 DBCC CHECKTABLE 和 CHECKALLOC)常常在表上控制共享锁 (S),因而阻塞了所有的数据修改语言 (DML) 语句。
在 SQL Server 2000 中,当检查表时 DBCC CHECKDB 在表上控制架构锁以防止元数据的更改,因而允许在正在检查的表上使用除任何数据定义语言 (DDL) 语句之外的 DML 语句。该变化对于决定何时运行 DBCC CHECKDB 提供了更大的灵活性,因为 DBCC CHECKDB 并不完全拒绝用户对系统的使用。
DBCC CHECKDB 是大量占用 CPU 和磁盘的操作。每一个需要检查的数据页都必须首先从磁盘读入内存。另外,DBCC CHECKDB 使用 tempdb 排序。
如果在 DBCC CHECKDB 运行时动态执行事务,那么事务日志会继续增长,因为 DBCC 命令在完成日志的读取之前阻塞日志截断。
建议在服务器负荷较少的时候运行 DBCC CHECKDB。如果在负荷高峰期运行 DBCC CHECKDB,那么事务吞吐量性能和 DBCC CHECKDB 完成时间性能都会受到影响。
要获得好的 DBCC 性能的一些建议
- 在系统使用率较低时运行 CHECKDB。
- 请确保未同时执行其它磁盘 I/O 操作,例如磁盘备份。
- 将 tempdb 放到单独的磁盘系统或快速磁盘子系统中。
- 允许 tempdb 在驱动器上有足够的扩展空间。使用带有 ESTIMATE ONLY 的 DBCC 估计 tempdb 将需要多少空间。
- 避免运行占用大量 CPU 的查询或批处理作业。
- 在 DBCC 命令运行时,减少活动事务。
- 使用 NO_INFOMSGS 选项显著减少处理和 tempdb 的使用。
考虑使用带有 PHYSICAL_ONLY 选项的 DBCC CHECKDB 来检查页和记录首部的物理结构。当硬件导致的错误被置疑时,这个操作将执行快速检查。
SQL2000数据修复命令DBCC用法
MS Sql Server 提供了很多数据库修复的命令,当数据库质疑或是有的无法完成读取时可以尝试这些修复命令。
1. DBCC CHECKDB
重启服务器后,在没有进行任何操作的情况下,在SQL查询分析器中执行以下SQL进行数据库的修复,修复数据库存在的一致性错误与分配错误。
use master
declare @databasename varchar(255)
set @databasename='需要修复的数据库实体的名称'
exec sp_dboption @databasename, N'single', N'true' --将目标数据库置为单用户状态
dbcc checkdb(@databasename,REPAIR_ALLOW_DATA_LOSS)
dbcc checkdb(@databasename,REPAIR_REBUILD)
exec sp_dboption @databasename, N'single', N'false'--将目标数据库置为多用户状态
然后执行 DBCC CHECKDB('需要修复的数据库实体的名称') 检查数据库是否仍旧存在错误。注意:修复后可能会造成部分数据的丢失。
2. DBCC CHECKTABLE
如果DBCC CHECKDB 检查仍旧存在错误,可以使用DBCC CHECKTABLE来修复。
use 需要修复的数据库实体的名称
declare @dbname varchar(255)
set @dbname='需要修复的数据库实体的名称'
exec sp_dboption @dbname,'single user','true'
dbcc checktable('需要修复的数据表的名称',REPAIR_ALLOW_DATA_LOSS)
dbcc checktable('需要修复的数据表的名称',REPAIR_REBUILD)
------把’ 需要修复的数据表的名称’更改为执行DBCC CHECKDB时报错的数据表的名称
exec sp_dboption @dbname,'single user','false'
3. 其他的一些常用的修复命令
DBCC DBREINDEX 重建指定数据库中表的一个或多个索引
用法:DBCC DBREINDEX (表名,’’) 修复此表所有的索引。
4.DBCC SHRINKFILE (设备文件名或id, 目标大小)
DBCC SHRINKFILE (tempdev, 200)
收缩数据库文件tempdev到200MB
DBCC SHRINKFILE (templog, 100)
收缩数据库文件templog到100MB
清除日志文件
backup log 数据库名 with NO_LOG
dbcc shrinkDatabase(数据库名)
例:将tempdb文件设定大小为50M:
USE tempdb
DBCC SHRINKFILE(tempdb,50)
相关推荐
DBCC CHECKDB 数据库或表修复
DBCCCHECKDB用法手工修复数据库
DBCCCHECKDB数据库或表修复.pdf
3. 使用DBCC CHECKDB命令检查数据库中的错误: DBCC CHECKDB(‘db_name') GO 4. 先将数据库置为单用户模式,再尝试对其进行修复: sp_dboption 'db_name','single user','true' DBCC CHECKDB(‘db_name', REPAIR_...
MS(DBCCCHECKDB)SqlServer数据库或表修复参照.pdf
所有的DBCC命令数据库修复数据库修复数据库修复数据库修复数据库修复数据库修复
DBCC CHECKDB ('数据库名称') --i.要修复数据库必需将数据库改为单用户模式: Exec sp_dboption '数据库名称','single user','true'---('true'单用户) --j.执行以下语句修复数据库: DBCC CHECKDB('数据库名称',...
在SQL Server 2000时代,一个叫Steve Lindell的哥们(现在仍然在SQL Server Team)使用分析事务日志的方法来检查数据库的一致性的方式重写了DBCC CHECKDB命令。DBCC CHECKDB会阻止截断日志。当将日志从头读到尾时...
如果DBCC checkdb('数据库名',REPAIR_A LLOW_DATA_LOSS)语句执行一次不行,可以在多执行几次直到没有再提示数据库有错误为止。 DBCC checkdb('数据库名',REPAIR_ALLOW_DATA_LOSS) --设置为多用户模式 sp_dboption '...
Sql-Server实用操作-数据库一致性检测工具(DBCC).pdf
用户可以选择运行程序,执行DBCC CHECKDB(yourdbname)与ALL_ERRORMSGS,NO_INFOMSGS来解决可能的错误和修复损坏的文件。然而,在严重受损的SQL文件的情况下,对于SQL数据库软件是一个恢复已删除或损坏的工具,使...
支持 SQL数据库DBCC 无法修复的 数据库数据恢复 支持 SQL数据库被勒索病毒加密的数据恢复。(大多被加密数据库都是非完全加密) 支持 blob,image,xml, 跨页数据以及文本大字段恢复 支持 sql数据库多用户架构,...
资源描述了 一般SQL数据库无法附加的解决方法,和 极佳数据库急救中心完美的修复方案.
1. DBCC CHECKDB 重启服务器后,在没有进行任何操作的情况下,在SQL查询分析器中执行以下SQL进行数据库的修复,修复数据库存在的一致性错误与分配错误。 use master declare @databasename varchar(255) set @...
SQL Server 2005完结篇系列之五:使用DBCC命令来进行数据库的维护及性能调节SQL Server 2005完结篇系列之五:使用DBCC命令来进行数据库的维护及性能调节SQL Server 2005完结篇系列之五:使用DBCC命令来进行数据库的...
使用BACKUP … WITH CHECKSUM可以替代DBCC CheckDB错误 乍一看,由于BACKUP WITH CHECKSUM会检测所有分配出去的页的校验和的值,这个误区貌似是这么回事,但实际上并不是这么回事,原因如下: 由SQL Server 2000...
SQL Server 2000完结篇系列之五:使用DBCC命令来进行数据库的维护及性能调节
国内目前最专业的数据库救援站,长期修复研究各数据库的物理结构及逻辑结构,我们的辛勤付出,换来了今日的数据库修复领先技术,长期快速 高效的恢复各种财务数据库 ERP管理数据库。在我们的实际修复案例中,绝大...