承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

Sql Server中的DBCC命令详细介绍

管理员 2023-06-27 08:39:35 互联网圈 14 ℃ 0 评论 10814字 收藏

     今天研发中心办年会,晚上就是各自部门聚餐了,我个人喜欢喝干红,在干红中你可以体味到那种酸甜苦辣。。。人生未尝不是这样呢???正好ceo从美国带了干红回来,然后我就顺道开心的过了把瘾。。。。一个字。。。爽。。。。喝着有点多。。。到现在头还疼。。。。回来地铁上想这个周末忙着找房子,书一点都没看,也没在博客上接着忽悠,想起了上篇博客有个哥们说普及普及DBCC,虽然有点迷迷糊糊的。。。看能不能写出点新花样。。。。不管学甚么语言,或者数据库,你得看的比人家深一层。。。最可悲的就是停留的在表层,这样每次版本升级后,出了些新花样,然后你就觉得太他妈奇异了,可事实真的是这样么?有个很现实的例子就是C#各个版本中的语法糖。。。。。当你ILdasm以后,你会发现都是些基础不能再

基础的东西,C#有个好处,就是你可以看源码,你还可以ILdasm它。。。基本上你就能够让它裸着来见你,但sqlserver有点特殊,它不是编程语言,你肯定不会通过反编译来学习,那它更深一层的东西就只能是底层的数据页了。.  。所以这个是学习sqlserver的基本功,扯的有点多。。。

 一:DBCC

1:甚么是DBCC

  我不是教学老师,我也说不到没有任何无懈可击的定义,全名:Database Console Commands。顾名思义“数据库控制台命令”,说到“控制台“,我第一反应就是chrome的开发者工具,不知道你的第一反应会是怎样?开发者工具中,只要javascript能认的语法,你都可以在控制台键入。。。一样的道理sqlserver能认的也是一样。

 2:DBCC到底有多少个命令

   你应当知道,凡是控制台,大多都会提供一个help命令,比如cmd界面,又或是mongodbのconsole,

 然后看看DBCC中的help会是怎样???

 从上图中,我从上到下数了下,有32个命令,不过成心思的是,微软提供的这32个命令其实都是些对外公然的,我这么说的意思是还有些未公然的命令只是微软自己用。。。。我可让你眼见为实。

从上面我们大概也看到了,公然和未公然的dbcc命令,加起来大约有100个,但是你要问我这些dbcc命令怎样用。。。我也告知不了你,毕竟我的头脑没有那末发达去记这些无聊的东西,再说也不想花时间专门的去记这些东西,就像英语的记单词一样。。。但是办法或者有的,大多东西都禁不住死缠烂打的,对女孩子也这样,要末缠到她喜欢上你,要末缠到她报警把你抓了。

 3:如何记住DBCC命令

<1> 联机丛书

   联机丛书可以说是sqlserver之母,在这个世界上你不会找到有比它还要权威,还要全的资料了,你可以点击这里看看它的神威,然后你就能够

键入dbcc,去寻觅你需要寻觅的东西,从下图中也看到,dbcc大概也是分为4类的,比较遗憾的是,未公然的dbcc命令在联机丛书上是找不到的。

<2> help(‘xxx’)

  如果你对命令的用法有了大概认知,但是一时忘了怎样赋参数,这时候候你就能够用help(‘xxx’)来帮助你节省开发时间,比如说buffer和ind命令。

 二:经常使用命令的实践

1: DBCC TRACEON

     联机丛书上说,这个就是启用指定的跟踪标志,既然说指定,这个就内涵了。。。我经常使用来研究的只有二个:

<1> TRACEON(2588)

   这个刚才你也知道了,指定了2588标记的话,你就能够看到未公然的dbcc命令了,同时你也能够看到各种命令参数的提示了。

<2> TRACEON(3604)

   这个指定的标记就是可以将DBCC Page的结果显示在客户端,否则就显示不出来了,不知道你在前面几章中会不会有注意到呢???  

 2:DBCC IND

 这个命令在本系列中会非常频繁的使用,由于它就是用来查看”堆表“或”索引“的数据页信息,没有它的话,我就无所研究了,或者老规矩,先看看

它的参数信息,以下图:

前两个参数我想你好理解,我在前面小节中也说到了,一个是dbname,一个是tablename or viewname or procname等等,第三个参数是最

成心思的,这里面的1,0,⑴,⑵ 是甚么意思呢???

 

<1> 1: 显示聚集索引数据页信息和IAM跟踪数据页信息。

<2> 0:   显示堆表数据页信息和IAM跟踪数据页信息。

<3>⑴: 显示所有数据页信息,比如(IAM,索引数据页,堆表数据页)。

<4>⑵: 显示IAM数据页信息。

<5>nonclustered indid: 从这个参数的排位列表,你大概也能看到是一个”正无穷大“到1,0,⑴,⑵这类模式,仔细想一想这个意思我想你也明白,比如

            说2就代表第一个非聚集索引,3代表第二个非聚集索引,以此类推。。。。。

 

真不想举例子,由于再往下说的话,就说不尽了。。。算了,或者举一个例子吧:

 

通过上面的图,我想你应当明白我在做甚么了吧???可以看到当前非聚集索引的数据散布在(PageFID:PagePID)(1:110) ,(1:115)….等4个数据页上,可以看到(1:114)只是他们的数据跟踪页。有人可能会说,我怎样看出来是IAM跟踪页呢?你只需看IAMFID和IAMPID为null就能够认为是IAM跟踪页了,当你看到IndexID>0的话,它就是索引页了。

 

3:DBCC PAGE

 这个命令也是本系列频繁触及到的,由于它确切太有用了,当我用IND导出数据页后,下一步就是一定要看看这个数据页中到底都有哪几种信息,人都是这样具有贪欲的,诱惑呀~~~老规矩,先看看参数。

从图中可以看到,第二和第三这两个参数没有甚么意思,由于我已用IND查询出了索引在哪些数据页(fileID:pageID)上面了,下面我们仔细

看看第四个参数。

<1> 0:输出可读情势的数据页页头数据,缘由是这样的,在一个数据页中,有96个字节空间来表示一个数据页头,里面的内容可丰富啦。。。。

<2> 1:输出可读情势的数据页页头数据,并且还有槽位对应记录的十六进制内容。  

<2> 2:输出全部数据页页头的十六进制数据,包括(页头,内容 和 slot),这个是我最经常使用的命令。

<3> 3:输出可读情势的数据页页头数据,并且包括记录中每一个字段的可读情势。

 

上面的命令看起来有点玄乎,我就只举一个例子,其他的留给大家试试看啦~~~

DBCC TRACEON(3604)
DBCC PAGE(Ctrip,1,110,2)

DBCC 履行终了。如果 DBCC 输出了毛病信息,请与系统管理员联系。

PAGE: (1:110)

BUFFER:

BUF @0x0000000085F8ED00

bpage = 0x000000008519A000 bhash = 0x0000000000000000 bpageno = (1:110)
bdbid = 8 breferences = 0 bUse1 = 8576
bstat = 0x3c00009 blog = 0x32159 bnext = 0x0000000000000000

PAGE HEADER:

Page @0x000000008519A000

m_pageId = (1:110) m_headerVersion = 1 m_type = 2
m_typeFlagBits = 0x0 m_level = 0 m_flagBits = 0x204
m_objId (AllocUnitId.idObj) = 58 m_indexId (AllocUnitId.idInd) = 256
Metadata: AllocUnitId = 72057594041729024
Metadata: PartitionId = 72057594040877056 Metadata: IndexId = 2
Metadata: ObjectId = 245575913 m_prevPage = (0:0) m_nextPage = (1:115)
pminlen = 909 m_slotCnt = 8 m_freeCnt = 784
m_freeData = 7392 m_reservedCnt = 0 m_lsn = (141:194:170)
m_xactReserved = 0 m_xdesId = (0:0) m_ghostRecCnt = 0
m_tornBits = ⑺88728362

Allocation Status

GAM (1:2) = ALLOCATED SGAM (1:3) = ALLOCATED
PFS (1:1) = 0x60 MIXED_EXT ALLOCATED 0_PCT_FULL DIFF (1:6) = CHANGED
ML (1:7) = NOT MIN_LOGGED

DATA:

Memory Dump @0x0000000010CEA000

0000000010CEA000: 01020000 04020001 00000000 00008d03 †…………….
0000000010CEA010: 73000000 01000800 3a000000 1003e01c †s…….:…….
0000000010CEA020: 6e000000 01000000 8d000000 c2000000 †n……………
0000000010CEA030: aa000000 00000000 00000000 d6f5fcd0 †…………….
0000000010CEA040: 00000000 00000000 00000000 00000000 †…………….

………..

0000000010CEBFE0: 21212121 21212121 21212121 21212121 †!!!!!!!!!!!!!!!!
0000000010CEBFF0: 5019c015 3012a00e 100b8007 f0036000 †P…0………`.

OFFSET TABLE:

Row – Offset
7 (0x7) – 6480 (0x1950)
6 (0x6) – 5568 (0x15c0)
5 (0x5) – 4656 (0x1230)
4 (0x4) – 3744 (0xea0)
3 (0x3) – 2832 (0xb10)
2 (0x2) – 1920 (0x780)
1 (0x1) – 1008 (0x3f0)
0 (0x0) – 96 (0x60)

DBCC 履行终了。如果 DBCC 输出了毛病信息,请与系统管理员联系。

文章来源:丸子建站

文章标题:Sql Server中的DBCC命令详细介绍

https://www.wanzijz.com/view/59846.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信