日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

          歡迎訪問 生活随笔!

          生活随笔

          當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

          编程问答

          Sql Server之旅——第五站 确实不得不说的DBCC命令

          發(fā)布時間:2025/3/15 编程问答 35 豆豆
          生活随笔 收集整理的這篇文章主要介紹了 Sql Server之旅——第五站 确实不得不说的DBCC命令 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
          Sql Server之旅——第五站 確實不得不說的DBCC命令 原文:Sql Server之旅——第五站 確實不得不說的DBCC命令

          ?  

          ? ? ?今天研發(fā)中心辦年會,晚上就是各自部門聚餐了,我個人喜歡喝干紅,在干紅中你可以體味到那種酸甜苦辣。。。人生何嘗不是這樣呢???正好

          ceo從美國帶了干紅回來,然后我就順道開心的過了把癮。。。。一個字。。。爽。。。。喝著有點多。。。到現(xiàn)在頭還疼。。。。回來地鐵上想這個

          周末忙著找房子,書一點都沒看,也沒在博客上接著忽悠,想起了上篇博客有個哥們說普及普及DBCC,雖然有點迷迷糊糊的。。。看能不能寫出點新

          花樣。。。。不管學什么語言,還是數(shù)據(jù)庫,你得看的比人家深一層。。。最可悲的就是停留的在表層,這樣每次版本升級后,出了些新花樣,然后你

          就覺得太他媽神奇了,可事實真的是這樣么?有個很現(xiàn)實的例子就是C#各個版本中的語法糖。。。。。當你ILdasm之后,你會發(fā)現(xiàn)都是些基礎不能再

          基礎的東西,C#有個好處,就是你可以看源碼,你還可以ILdasm它。。。基本上你就可以讓它裸著來見你,但sqlserver有點特殊,它不是編程語言,

          你肯定不會通過反編譯來學習,那它更深一層的東西就只能是底層的數(shù)據(jù)頁了。. ?。所以這個是學習sqlserver的基本功,扯的有點多。。。

          ?

          一:DBCC

          1:什么是DBCC

            我不是教學老師,我也說不到?jīng)]有任何無懈可擊的定義,全名:Database Console Commands。顧名思義“數(shù)據(jù)庫控制臺命令”,說到“控制臺“,

          我第一反應就是chrome的開發(fā)者工具,不知道你的第一反應會是怎樣?開發(fā)者工具中,只要javascript能認的語法,你都可以在控制臺鍵入。。。同

          樣的道理sqlserver能認的也是一樣。

          ?

          2:DBCC到底有多少個命令

            ?你應該知道,凡是控制臺,大多都會提供一個help命令,比如cmd界面,又或者是mongodbのconsole,

          ?

          然后看看DBCC中的help會是怎樣???

          ?

          從上圖中,我從上到下數(shù)了下,有32個命令,不過有意思的是,微軟提供的這32個命令其實都是些對外公開的,我這么說的意思是還有些未公開的命令只

          是微軟自己用。。。。我可以讓你眼見為實。

          從上面我們大概也看到了,公開和未公開的dbcc命令,加起來大約有100個,但是你要問我這些dbcc命令怎么用。。。我也告訴不了你,畢竟我的腦子

          沒有那么發(fā)達去記這些無聊的東西,再說也不想花時間專門的去記這些東西,就像英語的記單詞一樣。。。但是辦法還是有的,大多東西都禁不住死纏

          爛打的,對女孩子也這樣,要么纏到她喜歡上你,要么纏到她報警把你抓了。

          ?

          3:如何記住DBCC命令

          <1> 聯(lián)機叢書

             聯(lián)機叢書可以說是sqlserver之母,在這個世界上你不會找到有比它還要權威,還要全的資料了,你可以點擊這里看看它的神威,然后你就可以

          鍵入dbcc,去尋找你需要尋找的東西,從下圖中也看到,dbcc大概也是分為4類的,比較遺憾的是,未公開的dbcc命令在聯(lián)機叢書上是找不到的。

          <2> help('xxx')

            如果你對命令的用法有了大概認知,但是一時忘了怎么賦參數(shù),這時候你就可以用help('xxx')來幫助你節(jié)省開發(fā)時間,比如說buffer和ind命令。

          ?

          二:常用命令的實踐

          1: DBCC?TRACEON

          ? ? ?聯(lián)機叢書上說,這個就是啟用指定的跟蹤標志,既然說指定,這個就內(nèi)涵了。。。我常用來研究的只有二個:

          <1> TRACEON(2588)

             這個剛才你也知道了,指定了2588標記的話,你就可以看到未公開的dbcc命令了,同時你也可以看到各種命令參數(shù)的提示了。

          <2> TRACEON(3604)

             這個指定的標記就是可以將DBCC Page的結果顯示在客戶端,否則就顯示不出來了,不知道你在前面幾章中是否有注意到呢??? ?

          ?

          2:DBCC IND

           這個命令在本系列中會非常頻繁的使用,因為它就是用來查看”堆表“或者”索引“的數(shù)據(jù)頁信息,沒有它的話,我就無所研究了,還是老規(guī)矩,先看看

          它的參數(shù)信息,如下圖:

          前兩個參數(shù)我想你好理解,我在前面小節(jié)中也說到了,一個是dbname,一個是tablename or viewname or procname等等,第三個參數(shù)是最

          有意思的,這里面的1,0,-1,-2 是什么意思呢???

          ?

          <1> 1: 顯示聚集索引數(shù)據(jù)頁信息和IAM跟蹤數(shù)據(jù)頁信息。

          <2> 0: ? 顯示堆表數(shù)據(jù)頁信息和IAM跟蹤數(shù)據(jù)頁信息。

          <3>-1: 顯示所有數(shù)據(jù)頁信息,比如(IAM,索引數(shù)據(jù)頁,堆表數(shù)據(jù)頁)。

          <4>-2: 顯示IAM數(shù)據(jù)頁信息。

          <5>nonclustered indid: 從這個參數(shù)的排位列表,你大概也能看到是一個”正無限大“到1,0,-1,-2這種模式,仔細想想這個意思我想你也明白,比如

                      說2就代表第一個非聚集索引,3代表第二個聚集索引,以此類推。。。。。

          ?

          真不想舉例子,因為再往下說的話,就說不盡了。。。算了,還是舉一個例子吧:

          ?

          通過上面的圖,我想你應該明白我在做什么了吧???可以看到當前非聚集索引的數(shù)據(jù)分布在(PageFID:PagePID)(1:110) ,(1:115)....等4個數(shù)

          據(jù)頁上,可以看到(1:114)只是他們的數(shù)據(jù)跟蹤頁。有人可能會說,我怎么看出來是IAM跟蹤頁呢?你只需看IAMFID和IAMPID為null就可以認為是

          IAM跟蹤頁了,當你看到IndexID>0的話,它就是索引頁了。

          ?

          3:DBCC PAGE

           這個命令也是本系列頻繁涉及到的,因為它確實太有用了,當我用IND導出數(shù)據(jù)頁后,下一步就是一定要看看這個數(shù)據(jù)頁中到底都有哪些信息,人

          都是這樣具有貪欲的,誘惑呀~~~老規(guī)矩,先看看參數(shù)。

          從圖中可以看到,第二和第三這兩個參數(shù)沒有什么意思,因為我已經(jīng)用IND查詢出了索引在哪些數(shù)據(jù)頁(fileID:pageID)上面了,下面我們仔細

          看看第四個參數(shù)。

          <1> 0:輸出可讀形式的數(shù)據(jù)頁頁頭數(shù)據(jù),原因是這樣的,在一個數(shù)據(jù)頁中,有96個字節(jié)空間來表示一個數(shù)據(jù)頁頭,里面的內(nèi)容可豐富啦。。。。

          <2> 1:輸出可讀形式的數(shù)據(jù)頁頁頭數(shù)據(jù),并且還有槽位對應記錄的十六進制內(nèi)容。  

          <2> 2:輸出整個數(shù)據(jù)頁頁頭的十六進制數(shù)據(jù),包括(頁頭,內(nèi)容 和 slot),這個是我最常用的命令。

          <3> 3:輸出可讀形式的數(shù)據(jù)頁頁頭數(shù)據(jù),并且包括記錄中每個字段的可讀形式。

          ?

          上面的命令看起來有點玄乎,我就只舉一個例子,其他的留給大家試試看啦~~~

          DBCC TRACEON(3604) DBCC PAGE(Ctrip,1,110,2) 1 DBCC 執(zhí)行完畢。如果 DBCC 輸出了錯誤信息,請與系統(tǒng)管理員聯(lián)系。 2 3 PAGE: (1:110) 4 5 6 BUFFER: 7 8 9 BUF @0x0000000085F8ED00 10 11 bpage = 0x000000008519A000 bhash = 0x0000000000000000 bpageno = (1:110) 12 bdbid = 8 breferences = 0 bUse1 = 8576 13 bstat = 0x3c00009 blog = 0x32159 bnext = 0x0000000000000000 14 15 PAGE HEADER: 16 17 18 Page @0x000000008519A000 19 20 m_pageId = (1:110) m_headerVersion = 1 m_type = 2 21 m_typeFlagBits = 0x0 m_level = 0 m_flagBits = 0x204 22 m_objId (AllocUnitId.idObj) = 58 m_indexId (AllocUnitId.idInd) = 256 23 Metadata: AllocUnitId = 72057594041729024 24 Metadata: PartitionId = 72057594040877056 Metadata: IndexId = 2 25 Metadata: ObjectId = 245575913 m_prevPage = (0:0) m_nextPage = (1:115) 26 pminlen = 909 m_slotCnt = 8 m_freeCnt = 784 27 m_freeData = 7392 m_reservedCnt = 0 m_lsn = (141:194:170) 28 m_xactReserved = 0 m_xdesId = (0:0) m_ghostRecCnt = 0 29 m_tornBits = -788728362 30 31 Allocation Status 32 33 GAM (1:2) = ALLOCATED SGAM (1:3) = ALLOCATED 34 PFS (1:1) = 0x60 MIXED_EXT ALLOCATED 0_PCT_FULL DIFF (1:6) = CHANGED 35 ML (1:7) = NOT MIN_LOGGED 36 37 DATA: 38 39 40 Memory Dump @0x0000000010CEA000 41 42 0000000010CEA000: 01020000 04020001 00000000 00008d03 ?................ 43 0000000010CEA010: 73000000 01000800 3a000000 1003e01c ?s.......:....... 44 0000000010CEA020: 6e000000 01000000 8d000000 c2000000 ?n............... 45 0000000010CEA030: aa000000 00000000 00000000 d6f5fcd0 ?................ 46 0000000010CEA040: 00000000 00000000 00000000 00000000 ?................ 47 48 ........... 49 50 0000000010CEBFE0: 21212121 21212121 21212121 21212121 ?!!!!!!!!!!!!!!!! 51 0000000010CEBFF0: 5019c015 3012a00e 100b8007 f0036000 ?P...0.........`. 52 53 OFFSET TABLE: 54 55 Row - Offset 56 7 (0x7) - 6480 (0x1950) 57 6 (0x6) - 5568 (0x15c0) 58 5 (0x5) - 4656 (0x1230) 59 4 (0x4) - 3744 (0xea0) 60 3 (0x3) - 2832 (0xb10) 61 2 (0x2) - 1920 (0x780) 62 1 (0x1) - 1008 (0x3f0) 63 0 (0x0) - 96 (0x60) 64 65 66 DBCC 執(zhí)行完畢。如果 DBCC 輸出了錯誤信息,請與系統(tǒng)管理員聯(lián)系。

          ?

             ??~~~~~~~~~~~~~~~~~~~~~~最后就是研發(fā)中心年會中的那些靚景不敢一人獨享,給大家發(fā)福利啦~~~~~~~~~~~~~~~~~~~~~~

          ?

          ?

          ?

          ?

          ?

          posted on 2015-01-26 08:37 NET未來之路 閱讀(...) 評論(...) 編輯 收藏

          轉(zhuǎn)載于:https://www.cnblogs.com/lonelyxmas/p/4249365.html

          總結

          以上是生活随笔為你收集整理的Sql Server之旅——第五站 确实不得不说的DBCC命令的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

          如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

          主站蜘蛛池模板: 国产又色又爽又高潮免费 | 国产成人影视 | 国产欧美精品一区二区 | 久久精品久久精品 | 国产三级三级在线观看 | 精品国产理论 | jzjzz成人免费视频 | 久久成人免费 | 日本理论片 | 国产成人精品三级麻豆 | 国产富婆一区二区三区 | 芒果视频在线观看免费 | av性色 | 亚洲精选国产 | 国产人妖ts重口系列网站观看 | 中文字幕在线视频不卡 | 三级色视频 | av毛片在线免费观看 | 日韩精品极品视频 | 好吊色一区二区 | 国产欧美精品一区二区在线播放 | 日韩有码视频在线 | 精品av一区二区 | 国产高清一二三区 | 黑森林福利视频导航 | 成人福利视频网站 | 国产人成精品 | 成人国产精品免费观看视频 | av影片在线观看 | 麻豆一区产品精品蜜桃的特点 | 色妞色视频一区二区三区四区 | 精品免费一区二区 | 美女视频一区二区三区 | 波多野结衣高清电影 | 国产极品美女在线 | 精品影视 | 日本欧美成人 | 波多野结衣啪啪 | 国产一区色 | 精品丰满人妻无套内射 | 4438x全国最大成人网 | 免费观看成年人网站 | 中文字幕在线官网 | av网天堂 | 中文字幕观看在线 | 久久国产精品无码一级毛片 | 精品日本一区二区三区在线观看 | 香蕉久久av一区二区三区 | jjzzjjzz欧美69巨大 | 国产又色又爽无遮挡免费 | 五月婷婷色 | 国产美女又黄又爽又色视频免费 | 亚洲逼逼 | 四虎影院成人 | 国产97色在线 | 国产 | 欧美丰满熟妇bbb久久久 | 亚洲爱情岛论坛永久 | 青青草原一区二区 | 91国内精品视频 | 毛片毛片毛片毛片 | 在线播放成人 | 午夜影院欧美 | 国产精品国产馆在线真实露脸 | 男生女生羞羞网站 | 亚洲AV无码国产精品 | 毛片专区| 亚洲A∨无码国产精品 | 亚洲成人精选 | 成人免费做受小说 | 国产高清中文字幕 | 久草国产视频 | 一卡二卡在线 | 亚洲三级大片 | 久久亚洲AV成人无码国产野外 | 五月天狠狠操 | 日本少妇bb | 波多野吉衣中文字幕 | 美女131爽爽爽做爰视频 | www.一级片 | 成人看片 | 成人毛片在线 | 亚洲精品视频在线观看视频 | 国产精品中文字幕在线 | avt天堂网| 欧美体内she精高潮 日韩一区免费 | 偷偷操网站 | 五月激情在线 | 欧美激情福利 | 色爱综合| 成人va视频| 亚洲三级在线播放 | 伦理片波多野结衣 | 老熟妇仑乱一区二区视频 | 91涩涩视频| 中文字幕系列 | 国产一区二区综合 | 伊人色婷婷 | 国产破处av | 男男做的视频 |