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. 安装和配置VNC服务器的法则

    导读 这是一个关于怎样在你的 CentOS 7 上安装配置VNC服务的教程.当然这个教程也适合 RHEL 7 .在这个教程里,我们将学习什么是 VNC 以及怎样在 CentOS 7 上安装配置VNC ...

  2. BZOJ 1057: [ZJOI2007]棋盘制作

    Decsription 给你一个矩阵,求最大了 01相间 的矩阵. Sol DP+悬线法. 这是一个论文啊 <浅谈用极大化思想解决最大子矩形问题>--王知昆. 枚举每一根悬线,记录最左/右 ...

  3. swing复制文本框内容

    Clipboard clipboard = Toolkit.getDefaultToolkit().getSystemClipboard(); //得到系统剪贴板 String text = jTex ...

  4. java前后台之间传值的几种方式

    自己写的代码太少,有时候前后台传值还写的不是很熟练,现在总结一下,加深下印象. 1.jquery的Ajax传值 ---->前台到后台 期望功能:把前台用户输入的信息保存在数据库里. 前台jsp代 ...

  5. 【架构】How To Use HAProxy to Set Up MySQL Load Balancing

    How To Use HAProxy to Set Up MySQL Load Balancing Dec  2, 2013 MySQL, Scaling, Server Optimization U ...

  6. 为MongoDB创建一个Windows服务

    一:选型,根据机器的操作系统类型来选择合适的版本,使用下面的命令行查询机器的操作系统版本 wmic os get osarchitecture 二:下载并安装 附上下载链接 点击安装包,我这里是把文件 ...

  7. SQL Server OBJECT_ID() 函数

    OBJECT_ID 返回架构范围内对象的数据库对象标识号. 重要提示 使用 OBJECT_ID 不能查询非架构范围内的对象(如 DDL 触发器).对于在 sys.objects 目录视图中找不到的对象 ...

  8. IPC---信号量

    一.什么是信号量 信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程) 所拥有. 信号量的值为正的时候,说明它空闲.所测试的线程可以锁定而使用它.若为0,说明 它被占用,测试的线 ...

  9. 【leetcode】Symmetric Tree

    Symmetric Tree Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its ...

  10. Python之virtualenv安装

    CentOS 7 yum install python-virtualenv virtualenv --no-site-packages testenv #不依赖真实环境的packages用 --no ...