dbcc是sql server提供的一组控制台命令,主要用到数据库一致性检查与数据库修复操作。
一、dbcc 帮助类命令
* dbcc help('?')
查询所有的dbcc命令
* dbcc help('命令')
查询指定的dbcc命令的语法说明
* dbcc useroptions
返回当前连接的活动(设置)的set选项
二、dbcc 检查验证类命令
* dbcc checkallog ('数据库名称')
检查指定数据库的磁盘空间分配结构的一致性
* dbcc checkcatalog ('数据库名称')
检查指定数据库的系统表内和系统表间的一致性
* dbcc checkconstaints ('tablename')
检查指定表上的指定约束或所有约束的完整性
* dbcc checkdb
检查数据库中的所有对象的分配和结构完整性
* dbcc checkfilegroup
检查指定文件组中所有表在当前数据库中的分配和结构完整性
* dbcc checktable
检查指定表或索引视图的数据、索引及test、ntest和image页的完整性
* dbcc checkident
检查指定的当前标识值
* dbcc sqlperf(umsstats) undocumented in bol
可以用来检查是否cpu使用达到瓶颈
最关键的一个参考数据num runnable,表明当前有多少个线程再等待运行
如果大于等于2,考虑cpu达到瓶颈
三、dbcc 维护类命令
* dbcc cleantable ('db_name','table_name')
回收alter table drop column语句删除可变长度列或text
* dbcc dbreindex
重建指定数据库的一个或多个索引
* dbcc indexdefrag
对表或视图上的索引和非聚集索引进行碎片整理
* dbcc pintable (db_id,object_id)
将表数据驻留在内存中
查看哪些表驻留在内存的方法是:
select objectproperty(object_id('tablename'),‘tableispinned')
* dbcc unpintable (db_id,object_id)
撤消驻留在内存中的表
* dbcc shrinkdatabase(db_id,int)
收缩指定数据库的数据文件和
日志文件大小
* dbcc shrinkfile(file_name,int)
收缩相关数据库的指定数据文件和日志文件大小
四、dbcc 性能调节命令
* dbcc dllname(free)
sp_helpextendedproc 查看加载的扩展proc
在内存中卸载指定的扩展过程动态链接库(dll)
* dbcc dropcleanbuffers
从缓冲池中删除所有缓冲区
* dbcc freeproccache
从过程缓冲区删除所有元素
* dbcc inputbuffer
显示从客户机发送到
服务器的最后一个语句
* dbcc opentran (db_name)
查询某个数据库执行时间最久的事务,由哪个程序拥有
* dbcc show_statistics
显示指定表上的指定目标的当前分布统计信息
* dbcc showcontig
显示指定表的数据和索引的碎片信息
* dbcc sqlperf
(logspace) 查看各个db的日志情况
(iostats) 查看io情况
(threads) 查看线程消耗情况
返回多种有用的统计信息
* dbcc cachestats
显示sql server 2000内存的统计信息
* dbcc cursorstats
显示sql server 2000游标的统计信息
* dbcc memorystats
显示sql server 2000内存是如何细分的
* dbcc sqlmgrstats
显示缓冲中先读和预读准备的
sql语句
五、dbcc 未公开的命令
* dbcc errlog
初始化sql server 2000的错误日志文件
* dbcc flushprocindb (db_id)
清除sql server 2000服务器内存中的某个数据库的存储过程缓存内容
* dbcc buffer (db_name,object_name,int(缓冲区个数))
显示缓冲区的头部信息和页面信息
* dbcc dbinfo (db_name)
显示数据库的结构信息
* dbcc dbtable
显示管理数据的表(数据字典)信息
* dbcc ind (db_name,table_name,index_id)
查看某个索引使用的页面信息
* dbcc rebuildlog
重建sql server 2000事务日志文件
* dbcc log (db_name,3) (-1--4)
查看某个数据库使用的事物日志信息
* dbcc page
查看某个数据库数据页面信息
* dbcc procbuf
显示过程缓冲池中的缓冲区头和存储过程头
* dbcc prtipage
查看某个索引页面的每行指向的页面号
* dbcc pss (user,spid,1)
显示当前连接到sql server 2000服务器的进程信息
* dbcc resource
显示服务器当前使用的资源情况
* dbcc tab (db_id,object_id)
显示数据页面的结构
六、dbcc跟踪标记
跟踪标记用于临时设置服务器的特定特征或关闭特定行为,常用于诊断性能问题或调试存储过程或复杂的计算机系统
* dbcc traceon (3604)
打开跟踪标记
* dbcc traceoff
关闭跟踪标记
* dbcc tracestats
查看跟踪标记状态
七、使用 dbcc 结果集输出
许多 dbcc命令可以产生表格格式的输出(使用 with tableresults 选项)。该信息可装载到表中以便将来使用。以下显示一个示例脚本:
create table dbccresult (
dbccflag int,
result int
)
insert into dbccresult
exec ('dbcc tracestatus (-1) with no_infomsgs')
select *
from dbccresult
八、官方使用dbcc的建议
1、在系统使用率较低时运行 checkdb。
2、请确保未同时执行其它磁盘 i/o 操作,例如磁盘备份。
3、将 tempdb 放到单独的磁盘系统或快速磁盘子系统中。
4、允许 tempdb 在驱动器上有足够的扩展空间。 使用带有 estimate only 的 dbcc 估计 tempdb 将需要多少空间。
5、避免运行占用大量 cpu 的查询或批处理作业。
6、在 dbcc 命令运行时,减少活动事务。
7、使用 no_infomsgs 选项显著减少处理和 tempdb 的使用。
8、考虑使用带有 physical_only 选项的 dbcc checkdb 来检查页和记录首部 的物理结构。当硬件导致的错误被置疑时,这个操作将执行快速检查。
在发布,订阅复制时要用服务器实名时可以这样:
select * from sysservers (可以找到原来服务器的名称)
exec sp_dropserver 'jmsql9' (删除原来的服务器名)
exec sp_addserver 'jmsql9' ,local (改为新的服务器名)
alter database [jm] set single_user (改为单用户模式)
dbcc checkdb("databasename",repair_rebuild) with tablock (修复数据库)
dbcc checktable("tablename",repair_rebuild) with tablock (修复表)
dbcc dbreindex ('t_icitem' , ' ') 修复此表所有的索引。
alter database [jm] set multi_user (改为多用户模式)
repair_allow_data_loss:执行由repair_rebuild 完成的所有修复,包括对行和页进行分配和取消分配以改正分配错误、结构行或页的错误,以及删除已损坏的文本对象。
这些修复可能会导致一些数据丢失。修复操作可以在用户事务下完成以允许用户回滚所做的更改。
如果回滚修复,则数据库仍会含有错误,应该从备份进行恢复。
如果由于所提供修复等级的缘故遗漏某个错误的修复,则将遗漏任何取决于该修复的修复。修复完成后,备份数据库。
repair_fast 进行小的、不耗时的修复操作,如修复非聚集索引中的附加键。这些修复可以很快完成,并且不会有丢失数据的危险。
repair_rebuild 执行由repair_fast 完成的所有修复,包括需要较长时间的修复(如重建索引),执行这些修复时不会有丢失数据的危险。