dbcc命令集整理.sql 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341
  1. SQL SERVER DBCC命令集整理
  2. 1. DBCC CHECKALLOC 检查指定数据库的磁盘空间分配结构的一致性。
  3. DBCC CHECKALLOC www.2cto.com
  4. [
  5. (database_name | database_id | 0
  6. [ , NOINDEX
  7. | , { REPAIR_ALLOW_DATA_LOSS | REPAIR_FAST | REPAIR_REBUILD } ]
  8. )
  9. [ WITH
  10. {
  11. [ ALL_ERRORMSGS ]
  12. [ , NO_INFOMSGS ]
  13. [ , TABLOCK ]
  14. [ , ESTIMATEONLY ]
  15. }
  16. ]
  17. ]
  18. 2. DBCC CHECKCATALOG 检查指定数据库内的目录一致性。数据库必须联机。
  19. DBCC CHECKCATALOG
  20. [
  21. (
  22. database_name | database_id | 0
  23. )
  24. ]
  25. [ WITH NO_INFOMSGS ]
  26. 3. DBCC CHECKCONSTRAINTS 检查当前数据库中指定表上的指定约束或所有约束的完整性。
  27. DBCC CHECKCONSTRAINTS
  28. [
  29. (
  30. table_name | table_id | constraint_name | constraint_id
  31. )
  32. ]
  33. [ WITH
  34. [ { ALL_CONSTRAINTS | ALL_ERRORMSGS } ]
  35. [ , ] [ NO_INFOMSGS ]
  36. ]
  37. 4. DBCC CHECKDB 检查指定数据库中所有对象的逻辑和物理完整性
  38. DBCC CHECKDB
  39. [
  40. [ (database_name | database_id | 0
  41. [ , NOINDEX
  42. | , { REPAIR_ALLOW_DATA_LOSS | REPAIR_FAST | REPAIR_REBUILD } ]
  43. ) ]
  44. [ WITH
  45. {
  46. [ ALL_ERRORMSGS ]
  47. [ , EXTENDED_LOGICAL_CHECKS ]
  48. [ , NO_INFOMSGS ]
  49. [ , TABLOCK ]
  50. [ , ESTIMATEONLY ]
  51. [ , { PHYSICAL_ONLY | DATA_PURITY } ]
  52. }
  53. ]
  54. ]
  55. 5. DBCC CHECKFILEGROUP 检查当前数据库中指定文件组中的所有表和索引视图的分配和结构完整性.
  56. DBCC CHECKFILEGROUP
  57. [
  58. [ ( { filegroup_name | filegroup_id | 0 }
  59. [ , NOINDEX ]
  60. ) ]
  61. [ WITH
  62. {
  63. [ ALL_ERRORMSGS | NO_INFOMSGS ]
  64. [ , TABLOCK ]
  65. [ , ESTIMATEONLY ]
  66. [ , PHYSICAL_ONLY ]
  67. }
  68. ]
  69. ]
  70. 6. DBCC CHECKIDENT 在 SQL Server 2008 R2 中检查指定表的当前标识值,如有必要,则更改标识值。还可以使用 DBCC CHECKIDENT 为标识列手动设置新的当前标识值。
  71. DBCC CHECKIDENT
  72. (
  73. table_name
  74. [, { NORESEED | { RESEED [,new_reseed_value ] } } ]
  75. )
  76. [ WITH NO_INFOMSGS ]
  77. 7. DBCC CHECKTABLE 检查组成表或索引视图的所有页和结构的完整性。
  78. DBCC CHECKTABLE
  79. (
  80. table_name | view_name
  81. [ , { NOINDEX | index_id }
  82. |, { REPAIR_ALLOW_DATA_LOSS | REPAIR_FAST | REPAIR_REBUILD }
  83. ]
  84. )
  85. [ WITH
  86. { ALL_ERRORMSGS ]
  87. [ , EXTENDED_LOGICAL_CHECKS ]
  88. [ , NO_INFOMSGS ]
  89. [ , TABLOCK ]
  90. [ , ESTIMATEONLY ]
  91. [ , { PHYSICAL_ONLY | DATA_PURITY } ]
  92. }
  93. ]
  94. 8. DBCC CLEANTABLE 回收表或索引视图中已删除的可变长度列的空间。
  95. DBCC CLEANTABLE
  96. (
  97. { database_name | database_id | 0 }
  98. , { table_name | table_id | view_name | view_id }
  99. [ , batch_size ]
  100. )
  101. [ WITH NO_INFOMSGS ]
  102. 9. DBCC DBREINDEX 对指定数据库中的表重新生成一个或多个索引。
  103. DBCC DBREINDEX
  104. (
  105. table_name
  106. [ ,index_name [ ,fillfactor ] ]
  107. )
  108. [ WITH NO_INFOMSGS ]
  109. 10. DBCC dllname (FREE) 从内存中上载指定的扩展存储过程 DLL。
  110. DBCC dllname ( FREE ) [ WITH NO_INFOMSGS ]
  111. 11. DBCC DROPCLEANBUFFERS 从缓冲池中删除所有清除缓冲区。
  112. DBCC DROPCLEANBUFFERS [ WITH NO_INFOMSGS ]
  113. 12. DBCC FREEPROCCACHE 删除计划缓存中的所有元素,通过指定计划句柄或 SQL 句柄从计划缓存中删除特定计划,或者删除与指定资源池相关联的所有缓存条目。
  114. DBCC FREEPROCCACHE [ ( { plan_handle | sql_handle | pool_name } ) ] [ WITH NO_INFOMSGS ]
  115. 13. DBCC FREESESSIONCACHE 刷新针对 Microsoft SQL Server 实例执行的分布式查询所使用的分布式查询连接缓存。
  116. DBCC FREESESSIONCACHE [ WITH NO_INFOMSGS ]
  117. 14. DBCC FREESYSTEMCACHE 从所有缓存中释放所有未使用的缓存条目。SQL Server 数据库引擎会事先在后台清理未使用的缓存条目,以使内存可用于当前条目。但是,可以使用此命令从所有缓存中或者从指定的资源调控器池缓存中手动删除未使用的条目。
  118. DBCC FREESYSTEMCACHE
  119. ( 'ALL' [, pool_name ] )
  120. [WITH
  121. { [ MARK_IN_USE_FOR_REMOVAL ] , [ NO_INFOMSGS ] }
  122. ]
  123. 15. DBCC HELP 返回指定的 DBCC 命令的语法信息。
  124. DBCC HELP ( 'dbcc_statement' | @dbcc_statement_var | '?' )
  125. [ WITH NO_INFOMSGS ]
  126. 16. DBCC INDEXDEFRAG 指定表或视图的索引碎片整理。
  127. DBCC INDEXDEFRAG
  128. (
  129. { database_name | database_id | 0 }
  130. , { table_name | table_id | view_name | view_id }
  131. [ , { index_name | index_id } [ , { partition_number | 0 } ] ]
  132. )
  133. [ WITH NO_INFOMSGS ]
  134. 17. DBCC INPUTBUFFER 显示从客户端发送到 Microsoft SQL Server 实例的最后一个语句。
  135. DBCC INPUTBUFFER (session_id [ , request_id ])
  136. [WITH NO_INFOMSGS ]
  137. 18. DBCC OPENTRAN 如果在指定数据库内存在最早的活动事务和最早的分布式和非分布式复制事务,则显示与之有关的信息。仅当存在活动事务或数据库包含复制信息时,才显示结果。如果没有活动事务,就显示信息性消息。
  138. DBCC OPENTRAN
  139. [
  140. ( [ database_name | database_id | 0 ] ) ]
  141. { [ WITH TABLERESULTS ]
  142. [ , [ NO_INFOMSGS ] ]
  143. }
  144. ]
  145. 19. DBCC OUTPUTBUFFER 以十六进制和 ASCII 格式返回指定 session_id 的当前输出缓冲区。
  146. DBCC OUTPUTBUFFER ( session_id [ , request_id ])
  147. [ WITH NO_INFOMSGS ]
  148. 20. DBCC PROCCACHE 以表格格式显示有关过程缓存的信息。
  149. DBCC PROCCACHE [ WITH NO_INFOMSGS ]
  150. 21. DBCC SHOW_STATISTICS DBCC SHOW_STATISTICS 显示表或索引视图的当前查询优化统计信息。查询优化器使用统计信息估计查询结果中的基数或行数,这样,查询优化器可以创建高质量的查询计划。
  151. DBCC SHOW_STATISTICS ( table_or_indexed_view_name , target )
  152. [ WITH [ NO_INFOMSGS ] < option > [ , n ] ]
  153. < option > :: =
  154. STAT_HEADER | DENSITY_VECTOR | HISTOGRAM | STATS_STREAM
  155. 22. DBCC SHOWCONTIG 显示指定的表或视图的数据和索引的碎片信息。
  156. DBCC SHOWCONTIG
  157. [ (
  158. { table_name | table_id | view_name | view_id }
  159. [ , index_name | index_id ]
  160. ) ]
  161. [ WITH
  162. {
  163. [ , [ ALL_INDEXES ] ]
  164. [ , [ TABLERESULTS ] ]
  165. [ , [ FAST ] ]
  166. [ , [ ALL_LEVELS ] ]
  167. [ NO_INFOMSGS ]
  168. }
  169. ]
  170. 23. DBCC SHRINKDATABASE 收缩指定数据库中的数据文件和日志文件的大小。
  171. DBCC SHRINKDATABASE
  172. ( database_name | database_id | 0
  173. [ , target_percent ]
  174. [ , { NOTRUNCATE | TRUNCATEONLY } ]
  175. )
  176. [ WITH NO_INFOMSGS ]
  177. 24. DBCC SHRINKFILE 收缩当前数据库的指定数据或日志文件的大小,或通过将数据从指定的文件移动到相同文件组中的其他文件来清空文件,以允许从数据库中删除该文件。文件大小可以收缩到比创建该文件时所指定的大小更小。这样会将最小文件大小重置为新值。
  178. DBCC SHRINKFILE
  179. (
  180. { file_name | file_id }
  181. { [ , EMPTYFILE ]
  182. | [ [ , target_size ] [ , { NOTRUNCATE | TRUNCATEONLY } ] ]
  183. }
  184. )
  185. [ WITH NO_INFOMSGS ]
  186. 25. DBCC SQLPERF 提供所有数据库的事务日志空间使用情况统计信息。也可以用于重置等待和闩锁的统计信息。
  187. DBCC SQLPERF
  188. (
  189. [ LOGSPACE ]
  190. |
  191. [ "sys.dm_os_latch_stats" , CLEAR ]
  192. |
  193. [ "sys.dm_os_wait_stats" , CLEAR ]
  194. )
  195. [WITH NO_INFOMSGS ]
  196. 26. DBCC DBREPAIR 禁用指定的跟踪标记。
  197. DBCC TRACEOFF ( trace# [ ,...n ] [ , -1 ] ) [ WITH NO_INFOMSGS ]
  198. 27. DBCC TRACEON 启用指定的跟踪标记。
  199. DBCC TRACEON ( trace# [ ,...n ][ , -1 ] ) [ WITH NO_INFOMSGS ]
  200. 28. DBCC TRACESTATUS 显示跟踪标志的状态。
  201. DBCC TRACESTATUS ( [ [ trace# [ ,...n ] ] [ , ] [ -1 ] ] )
  202. [ WITH NO_INFOMSGS ]
  203. 29. DBCC UPDATEUSAGE 报告目录视图中的页数和行数错误并进行更正。这些错误可能导致 sp_spaceused 系统存储过程返回不正确的空间使用报告。
  204. DBCC UPDATEUSAGE
  205. ( { database_name | database_id | 0 }
  206. [ , { table_name | table_id | view_name | view_id }
  207. [ , { index_name | index_id } ] ]
  208. ) [ WITH [ NO_INFOMSGS ] [ , ] [ COUNT_ROWS ] ]
  209. 30. DBCC USEROPTIONS 返回当前连接的活动(设置)的 SET 选项。
  210. DBCC USEROPTIONS
  211. [ WITH NO_INFOMSGS ]
  212. --------------------------------------------------------------------------------------------------
  213. MS Sql Server 数据库或表修复(Log日志文件损坏的修复方法)
  214. ----------------- 【1】
  215. use master
  216. go
  217. sp_configure 'allow updates',1
  218. reconfigure with override
  219. go
  220. ----------------- 【2】
  221. update sysdatabases set status=-32768 where dbid=DB_ID('zc_post')
  222. ----------------- 【3】
  223. dbcc rebuild_log('zc_post','d:\zc_post_log.ldg')
  224. ----------------- 【4】
  225. dbcc checkdb('zc_post')
  226. ----------------- 【5】
  227. sp_dboption 'zc_post','dbo use only','false'
  228. ----------------- 【6】
  229. sp_configure 'allow updates',0
  230. go
  231. reconfigure with override
  232. go
  233. ============================================================ 【详细方法】
  234. [转]sql server 2000,Log.LDF文件丢失,附加数据库失败的解决办法
  235. 关键词:SQL Server数据库文件恢复技术 SQL Server日志文件丢失的恢复方法
  236.   SQL Server数据库备份有两种方式,一种是使用BACKUP DATABASE将数据库文件备份出去,另外一种就是直接拷贝数据库文件mdf和日志文件ldf的方式。下面将主要讨论一下后者的备份与恢复。本文假定您能熟练使用SQL Server Enterprise Manager(SQL Server企业管理器)和SQL Server Quwey Analyser(SQL Server查询分析器)
  237. 1、正常的备份、恢复方式
  238.   正常方式下,我们要备份一个数据库,首先要先将该数据库从运行的数据服务器中断开,或者停掉整个数据库服务器,然后复制文件。
  239.   卸下数据库的命令:Sp_detach_db 数据库名
  240. 连接数据库的命令:Sp_attach_db或者sp_attach_single_file_db
  241. -SQL
  242. s_attach_db [@dbname =] ′dbname′, [@filename1 =] ′filename_n′ [,...16]
  243. sp_attach_single_file_db [@dbname =] ′dbname′, [@physname =] ′physical_name′
  244.   使用此方法可以正确恢复SQL Sever7.0和SQL Server 2000的数据库文件,要点是备份的时候一定要将mdf和ldf两个文件都备份下来,mdf文件是数据库数据文件,ldf是数据库日志文件。
  245. 例子:
  246.   假设数据库为test,其数据文件为test_data.mdf,日志文件为test_log.ldf。下面我们讨论一下如何备份、恢复该数据库。
  247. 卸下数据库:
  248. -SQL
  249. sp_detach_db 'test'
  250. 连接数据库:
  251. -SQL
  252. sp_attach_db 'test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_data.mdf','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.ldf'
  253. sp_attach_single_file_db 'test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_data.mdf'
  254. 2、只有mdf文件的恢复技术
  255.   由于种种原因,我们如果当时仅仅备份了mdf文件,那么恢复起来就是一件很麻烦的事情了。
  256. 如果您的mdf文件是当前数据库产生的,那么很侥幸,也许你使用sp_attach_db或者sp_attach_single_file_db可以恢复数据库,但是会出现类似下面的提示信息
  257. 设备激活错误。物理文件名 'C:\Program Files\Microsoft SQL Server\MSSQL\data\test_Log.LDF' 可能有误。
  258. 已创建名为 'C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.LDF' 的新日志文件。
  259. sql server 2000,Log.LDF文件丢失
  260.   如果您的数据库文件是从其他计算机上复制过来的,那么很不幸,也许上述办法就行不通了。你也许会得到类似下面的错误信息
  261. 服务器: 消息 1813,级别 16,状态 2,行 1
  262. 未能打开新数据库 'test'。CREATE DATABASE 将终止。
  263. 设备激活错误。物理文件名 'd:\test_log.LDF' 可能有误。
  264.   怎么办呢?别着急,下面我们举例说明恢复办法。
  265.   A.我们使用默认方式建立一个供恢复使用的数据库(如test)。可以在SQL Server Enterprise Manager里面建立。
  266.   B.停掉数据库服务器。
  267.   C.将刚才生成的数据库的日志文件test_log.ldf删除,用要恢复的数据库mdf文件覆盖刚才生成的数据库数据文件test_data.mdf。
  268.   D.启动数据库服务器。此时会看到数据库test的状态为“置疑”。这时候不能对此数据库进行任何操作。
  269.   E.设置数据库允许直接操作系统表。此操作可以在SQL Server Enterprise Manager里面“工具-》SQL Server配置属性”,在“服务器设置”页面中将“允许对系统目录直接修改”一项选中。也可以使用如下语句来实现。
  270. -SQL
  271. use master
  272. go
  273. sp_configure 'allow updates',1
  274. go
  275. reconfigure with override
  276. go
  277.   F.设置test为紧急修复模式
  278. -SQL
  279. update sysdatabases set status=-32768 where dbid=DB_ID('test')
  280. 此时可以在SQL Server Enterprise Manager里面看到该数据库处于“只读\置疑\脱机\紧急模式”可以看到数据库里面的表,但是仅仅有系统表
  281.   G.下面执行真正的恢复操作,重建数据库日志文件
  282. -SQL
  283. dbcc rebuild_log('test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.ldf')
  284. 执行过程中,如果遇到下列提示信息:
  285. 服务器: 消息 5030,级别 16,状态 1,行 1
  286. 未能排它地锁定数据库以执行该操作。
  287. DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。[brown]
  288.   说明您的其他程序正在使用该数据库,如果刚才您在F步骤中使用SQL Server Enterprise Manager打开了test库的系统表,那么退出SQL Server Enterprise Manager就可以了。
  289.   正确执行完成的提示应该类似于:
  290. 警告: 数据库 'test' 的日志已重建。已失去事务的一致性。应运行 DBCC CHECKDB 以验证物理一致性。将必须重置数据库选项,并且可能需要删除多余的日志文件。
  291.   DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。
  292. 此时打开在SQL Server Enterprise Manager里面会看到数据库的状态为“只供DBO使用”。此时可以访问数据库里面的用户表了。
  293.   H.验证数据库一致性(可省略)
  294. -SQL
  295. dbcc checkdb('test')
  296. 一般执行结果如下:
  297. CHECKDB 发现了 0 个分配错误和 0 个一致性错误(在数据库 'test' 中)。
  298. DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。
  299.   I.设置数据库为正常状态
  300. -SQL
  301. sp_dboption 'test','dbo use only','false'
  302.   如果没有出错,那么恭喜,现在就可以正常的使用恢复后的数据库啦。
  303.   J.最后一步,我们要将步骤E中设置的“允许对系统目录直接修改”一项恢复。因为平时直接操作系统表是一件比较危险的事情。当然,我们可以在SQL Server Enterprise Manager里面恢复,也可以使用如下语句完成
  304. -SQL
  305. sp_configure 'allow updates',0
  306. go
  307. reconfigure with override
  308. go