DBCC是SQL Server提供的一组控制台命令,功能很强大,掌握一些必要的语句,对操作数据库有不少帮助,所以决定整理一下,发现已有不少类似的整理,减少了不少工作,归类如下:

一、DBCC 帮助类命令

* DBCC HELP('?') 
查询所有的DBCC命令 
* DBCC HELP('checktable') 
查询指定的DBCC命令的语法说明 
* DBCC USEROPTIONS 
返回当前连接的活动(设置)的SET选项

二、DBCC 检查验证类命令

* DBCC CHECKALLOC ('数据库名称') 
检查指定数据库的磁盘空间分配结构的一致性 
* 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 完成的所有修复,包括需要较长时间的修复(如重建索引),执行这些修复时不会有丢失数据的危险。

dbcc shrinkdatabase  (jm)      压缩数据库

九、关于db缓存清理的常用指令及其介绍

--1. 将当前数据库的全部脏页写入磁盘。“脏页”是已输入缓存区高速缓存且已修改但尚未写入磁盘的数据页。
-- CHECKPOINT 可创建一个检查点,在该点保证全部脏页都已写入磁盘,从而在以后的恢复过程中节省时间。
CHECKPOINT
--2. 若要从缓冲池中删除清除缓冲区,请首先使用 CHECKPOINT 生成一个冷缓存。这可以强制将当前数据库的全部脏页写入磁盘,然后清除缓冲区。
-- 完成此操作后,便可发出 DBCC DROPCLEANBUFFERS 命令来从缓冲池中删除所有缓冲区。
DBCC DROPCLEANBUFFERS
--3. 释放过程缓存将导致系统重新编译某些语句(例如,即席 SQL 语句),而不重用缓存中的语句。
DBCC FREEPROCCACHE
--4. 从所有缓存中释放所有未使用的缓存条目。SQL Server 2005 Database Engine 会事先在后台清理未使用的缓存条目,以使内存可用于当前条目。
-- 但是,可以使用此命令从所有缓存中手动删除未使用的条目。
DBCC FREESYSTEMCACHE ( 'ALL' )
--5. 要接着执行你的查询,不然SQLServer会时刻的自动往缓存里读入最有可能需要的数据页.

DBCC常用命令小汇的更多相关文章

  1. git命令小汇总和github

    Git 简介 是什么 Git 也是一个版本控制管理软件 有什么用,可以解决什么问题 保存历史记录 多人协作 有了 SVN,为啥要学 Git Git 火 Git 相对于 SVN 来说,更强大,用户也非常 ...

  2. (4.11)DBCC 常用命令

    三.DBCC状态.验证.其他语句 跟踪标识全集:https://www.cnblogs.com/lyhabc/articles/4092507.html 状态语句DBCC INPUTBUFFER 显示 ...

  3. php 常用英语小汇

    bstract抽象的 -挨伯丝拽克特 access存取.访问 -挨克色丝 account账户 -厄靠恩特 action动作 -爱克身 activate激活 -爱克特维特 active活动的 -爱克得 ...

  4. [转]CMD命令提示符窗口中的快捷键、小技巧和常用命令

    转至:https://wenku.baidu.com/view/d5d2b7ca360cba1aa811dac6.html 快捷键:  F1:按F1一次,命令提示符向后切换到已经执行过的命令字符.如果 ...

  5. 0、驱动及应用小技巧、uboot指令及环境变量配置、linux常用命令

    (内核make menuconfig之后,通过insmod安装的驱动都应该重新make,可能会出现一些莫名的问题) (nor flash/SDRAM/DM9000都受内存控制器控制,需要配置内存控制器 ...

  6. linux常用命令与实例小全

    转至:https://www.cnblogs.com/xieguohui/p/8296864.html  linux常用命令与实例小全 阅读目录(Content) 引言 一.安装和登录 (一)    ...

  7. Linux最常用命令的小总结

    目录及文件的基本操作: cd  .. 切换到当前目录的上一级目录 cd 切换工作目录至当前用户的家目录 cd - 返回到上一个打开的目录(像遥控器上的切换键,切换到上一个播放的电视频道) ll -h ...

  8. 第三章——使用系统函数、存储过程和DBCC SQLPERF命令来监控SQLServer(3)

    原文:第三章--使用系统函数.存储过程和DBCC SQLPERF命令来监控SQLServer(3) 本文为这个系列最后一篇.将是如何使用DBCC命令来监控SQLServer日志空间的使用情况. 前言: ...

  9. 97 条 Linux 常用命令及Vim命令总结

    一:Vim编辑模式命令 基本上Vim共分为3种模式,分别是一般模式,编辑模式和命令行模式,这三种模式的作用分别如下简述: 一般模式:默认模式.打开vim直接进入的是一般模式,在这个模式下,可以进行的操 ...

随机推荐

  1. FZU2127

    FZU2127:养鸡场 Problem Description Jason买来了n米长的竹篱笆,打算将n米长的竹篱笆所实用来围成一个三角形的养鸡场.为方便起见.养鸡场三条边的长度都为正整数. 同一时候 ...

  2. Tomcat7优化配置

    导读 Tomcat在使用的过程中会遇到很多报错,有些是程序的报错,但还有一部分是tomcat本身的报错,我们可以通过优化tomcat的初始配置来提高tomcat的性能.Tomcat的优化主要体现在两方 ...

  3. 据说Linuxer都难忘的25个画面

    导读 虽然对 Linux 正式生日是哪天还有些争论,甚至 Linus Torvalds 认为在 1991 那一年有四个日子都可以算作 Linux 的生日.但是不管怎么说,Linux 已经 25 岁了, ...

  4. net-snmp配置:snmp v3的安全配置

    net-snmp配置:snmp v3的安全配置 net-snmp配置:snmp v3的安全配置 增加snmp v3用户 增加 认证且加密只读账号(authPriv) 增加 认证且加密的读写账户 增加 ...

  5. linux下git安装

    Download for Linux and Unix It is easiest to install Git on Linux using the preferred package manage ...

  6. easyui只打开一个tab

    下面是JS代码: var curr = null; //curr为当前tab的标题,在else中赋值 function addtab(href, tabtitle) { if (curr) { $(' ...

  7. 一致性哈希算法以及其PHP实现

    在做服务器负载均衡时候可供选择的负载均衡的算法有很多,包括:  轮循算法(Round Robin).哈希算法(HASH).最少连接算法(Least Connection).响应速度算法(Respons ...

  8. 转帖: 使用脚本删除程序(免除在[控制面板]->[添加或删除程序]中的手工操作)

    1. 代码:VBS strComputer = "." '这个表示本地计算机 Set objWMIService = GetObject("winmgmts:" ...

  9. java 调用webservice的各种方法总结

    java 调用webservice的各种方法总结 几种流行的开源WebService框架Axis1,Axis2,Xfire,CXF,JWS比较 方法一:创建基于JAX-WS的webservice(包括 ...

  10. Android 自动化测试 常用的命令----随时更新

    常用命令分为三类,如下: 1. android android sdk : 打开SDK管理器. android avd : 打开虚拟设备管理器. android --help : 查看帮助信息. 2. ...