亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

Sql Server之旅——第五站 確實不得不說的DBCC命令(文后附年會福利)

2024-08-31 00:54:54
字體:
來源:轉載
供稿:網友
Sql Server之旅——第五站 確實不得不說的DBCC命令(文后附年會福利)

  

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

ceo從美國帶了干紅回來,然后我就順道開心的過了把癮。。。。一個字。。。爽。。。。喝著有點多。。。到現在頭還疼。。。?;貋淼罔F上想這個

周末忙著找房子,書一點都沒看,也沒在博客上接著忽悠,想起了上篇博客有個哥們說普及普及DBCC,雖然有點迷迷糊糊的。。??茨懿荒軐懗鳇c新

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

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

基礎的東西,C#有個好處,就是你可以看源碼,你還可以ILdasm它。。?;旧夏憔涂梢宰屗阒鴣硪娔悖玸qlserver有點特殊,它不是編程語言,

你肯定不會通過反編譯來學習,那它更深一層的東西就只能是底層的數據頁了。. 。所以這個是學習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: DBCCTRACEON

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

<1> TRACEON(2588)

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

<2> TRACEON(3604)

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

2:DBCC IND

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

它的參數信息,如下圖:

前兩個參數我想你好理解,我在前面小節中也說到了,一個是dbname,一個是tablename or viewname or PRocname等等,第三個參數是最

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

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

<2> 0: 顯示堆表數據頁信息和IAM跟蹤數據頁信息。

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

<4>-2: 顯示IAM數據頁信息。

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

            說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)
 1 DBCC 執行完畢。如果 DBCC 輸出了錯誤信息,請與系統管理員聯系。 2  3 PAGE: (1:110) 4  5  6 BUFFER: 7  8  9 BUF @0x0000000085F8ED0010 11 bpage = 0x000000008519A000           bhash = 0x0000000000000000           bpageno = (1:110)12 bdbid = 8                            breferences = 0                      bUse1 = 857613 bstat = 0x3c00009                    blog = 0x32159                       bnext = 0x000000000000000014 15 PAGE HEADER:16 17 18 Page @0x000000008519A00019 20 m_pageId = (1:110)                   m_headerVersion = 1                  m_type = 221 m_typeFlagBits = 0x0                 m_level = 0                          m_flagBits = 0x20422 m_objId (AllocUnitId.idObj) = 58     m_indexId (AllocUnitId.idInd) = 256  23 Metadata: AllocUnitId = 72057594041729024                                 24 Metadata: PartitionId = 72057594040877056                                 Metadata: IndexId = 225 Metadata: ObjectId = 245575913       m_prevPage = (0:0)                   m_nextPage = (1:115)26 pminlen = 909                        m_slotCnt = 8                        m_freeCnt = 78427 m_freeData = 7392                    m_reservedCnt = 0                    m_lsn = (141:194:170)28 m_xactReserved = 0                   m_xdesId = (0:0)                     m_GhostRecCnt = 029 m_tornBits = -788728362              30 31 Allocation Status32 33 GAM (1:2) = ALLOCATED                SGAM (1:3) = ALLOCATED               34 PFS (1:1) = 0x60 MIXED_EXT ALLOCATED   0_PCT_FULL                         DIFF (1:6) = CHANGED35 ML (1:7) = NOT MIN_LOGGED            36 37 DATA:38 39 40 Memory Dump @0x0000000010CEA00041 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 執行完畢。如果 DBCC 輸出了錯誤信息,請與系統管理員聯系。

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91视频免费在线| 亚洲一品av免费观看| 欧美怡红院视频一区二区三区| 久久91精品国产91久久久| 久久99热这里只有精品国产| 亚洲成人亚洲激情| 日韩av在线直播| 久久久久久国产精品三级玉女聊斋| 中文字幕日韩在线视频| 51午夜精品视频| 日韩激情在线视频| 国产suv精品一区二区三区88区| 欧美亚洲另类制服自拍| 亚洲最大av在线| 国产伦精品免费视频| 欧美高清在线视频观看不卡| 欧美激情一区二区三区久久久| 亚洲第一精品电影| 97超级碰碰人国产在线观看| 日韩精品视频免费专区在线播放| 欧美日本精品在线| 国产一区二区精品丝袜| 国产精品视频在线观看| 国产精品99久久久久久久久久久久| 欧美日韩国产精品一区二区不卡中文| 国产一区二区三区在线免费观看| 亚洲国产欧美一区二区丝袜黑人| 亚洲欧洲一区二区三区久久| 精品久久久国产| 久久伊人91精品综合网站| 欧美精品手机在线| 欧美第一页在线| 中文字幕免费精品一区高清| 91精品久久久久久久久久另类| 92国产精品视频| 国产精品久久97| 亚洲电影在线看| 久久久国产精彩视频美女艺术照福利| 日韩精品中文字幕在线播放| 九九热99久久久国产盗摄| 国产欧美一区二区三区四区| 日韩精品中文字幕在线播放| 亚洲男人的天堂在线| 成人午夜在线影院| 91国产视频在线播放| 成人美女免费网站视频| 亚洲黄色在线观看| 久久人人爽人人爽爽久久| 欧美日韩国产成人高清视频| 欧美性生活大片免费观看网址| 中文字幕在线看视频国产欧美在线看完整| 欧美激情成人在线视频| 美日韩精品视频免费看| 欧美高清在线播放| 欧美老女人性生活| 亚洲国产另类久久精品| 欧美性猛交xxxx| 日韩在线观看av| 欧美wwwwww| 亚洲精品一区中文| 欧美一二三视频| www亚洲欧美| 亚洲成人在线视频播放| 91香蕉嫩草神马影院在线观看| 92版电视剧仙鹤神针在线观看| 亚洲激情 国产| 色综久久综合桃花网| 日本免费一区二区三区视频观看| 日韩精品在线免费播放| 久久久久久亚洲精品不卡| 亚洲天堂免费观看| 国产精品稀缺呦系列在线| 成人黄色av播放免费| 亚洲专区中文字幕| 91热精品视频| 国产精品高清在线观看| 亚洲黄页视频免费观看| 久久99久久亚洲国产| 久久久国产精彩视频美女艺术照福利| 色综合久久天天综线观看| 久久精品中文字幕一区| 久久久久久亚洲精品不卡| 国产精品小说在线| 日韩成人av网| 国产精品久久久久久久久久久不卡| 亚洲女人天堂av| 欧美激情影音先锋| 91久久久在线| 蜜臀久久99精品久久久久久宅男| 国产精品久久91| 欧美激情在线播放| 久久av在线播放| 久青草国产97香蕉在线视频| 国产精品大陆在线观看| 91久久久精品| 国产精品亚洲美女av网站| 91精品在线观看视频| 亚洲乱码一区av黑人高潮| 国产91ⅴ在线精品免费观看| 久久精品小视频| 91免费精品视频| 456国产精品| 欧美富婆性猛交| 久久久久亚洲精品成人网小说| 国产高清视频一区三区| 久久国产精品影视| 91亚洲国产成人久久精品网站| 欧洲成人免费视频| 久久69精品久久久久久久电影好| 亚洲美女喷白浆| 原创国产精品91| 午夜精品久久久久久久久久久久久| 亚洲自拍欧美另类| 国产精品偷伦一区二区| 国产精品亚洲第一区| 国产精品入口日韩视频大尺度| 日韩精品在线视频| 91av视频在线观看| 亚洲国产女人aaa毛片在线| 日韩精品在线免费| 亚洲女人天堂av| 欧美成人一区二区三区电影| 亚洲色图日韩av| 91国自产精品中文字幕亚洲| 夜色77av精品影院| 亚洲人成在线免费观看| 国产精品欧美激情| 久久久国产视频91| 韩国国内大量揄拍精品视频| 亚洲偷欧美偷国内偷| 日韩性生活视频| 狠狠躁夜夜躁人人爽超碰91| 亚洲а∨天堂久久精品9966| 91免费版网站入口| 久久精品91久久久久久再现| 国内精品久久久久影院优| 黑人巨大精品欧美一区二区| 国产日韩欧美在线视频观看| 欧美日韩国产色| 青草青草久热精品视频在线观看| 亚洲欧美国产日韩天堂区| 欧美最近摘花xxxx摘花| 国模精品一区二区三区色天香| 国产欧美久久久久久| 欧美激情亚洲另类| 国产国产精品人在线视| 最近2019好看的中文字幕免费| 成人激情视频小说免费下载| 91美女高潮出水| 日韩av在线影视| 亚洲欧美日韩区| 国产精品成熟老女人| 亚洲日本欧美中文幕| 曰本色欧美视频在线| 亚洲色图色老头| 亚洲天堂av在线播放| 中文字幕日韩在线视频| 欧美性xxxxhd| 日本不卡免费高清视频| 亚洲人永久免费| 亚洲人成电影在线| 精品国产福利在线| 在线观看欧美视频| 久久久亚洲影院你懂的|