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

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

SQL Server誤區30日談 第13天 在SQL Server 2000兼容模式下不能使用DMV

2024-08-31 00:56:49
字體:
來源:轉載
供稿:網友

誤區 #13.在SQL Server 2000兼容模式下不能使用DMV

錯誤

對于兼容模式已經存在了很多誤解。80的兼容模式的數據庫是否意味著能夠附加或恢復到SQL Server 2000數據庫?當然不是。這只是意味著一些T-SQL的語法,查詢計劃的行為以及一些其它方面和SQL Server 2000中行為一樣(當然,如果你設置成90兼容模式則和SQL Server 2005中一樣)。

在SQL Server 2008中,你可以使用ALTER DATABASE SET COMPATIBILITY_LEVEL命令來改變兼容模式,對于SQL Server 2008之前的版本,則使用系統存儲過程sp_dbcmptlevel(譯者注:比如sp_dbcmptlevel @dbname='AdventureWorks',@new_cmptlevel=100),對于這兩種方式如何用,請看:

  • 對于SQL Server 2008,BOL入口ALTER DATABASE Compatibility Level
  • 對于SQL Server 2005,BOL入口sp_dbcmptlevel (Transact-SQL).
  • 兼容模式對于數據庫的實際版本毫無影響,數據庫的實際版本會隨著對于數據庫的升級而升級,這個升級會阻止更新版本的數據庫恢復或附加到之前的數據庫,因為之前版本的實例無法理解新版本數據庫的版本。如果想看詳細內容,請看我的一篇博文:Search Engine Q&A #13: Difference between database version and database compatibility level.還有如果當你附加新版數據庫到老版本實例時所遇到的錯誤信息:Msg 602, Level 21, State 50, Line 1。

    在SQL Server 2005中設置為80兼容模式,貌似DMV就不能用了,運行下面代碼創建測試數據庫:

    CREATE DATABASE DMVTest;
    GO
    USE DMVTest;
    GO
    CREATE TABLE t1 (c1 INT);
    CREATE CLUSTERED INDEX t1c1 on t1 (c1);
    INSERT INTO t1 VALUES (1);
    GO

    EXEC sp_dbcmptlevel DMVTest, 80;
    GO

    SELECT * FROM sys.dm_db_index_physical_stats (
    DB_ID ('DMVTest'), -- database ID
    OBJECT_ID ('t1'), -- object ID <<<<<< Note I'm using 1-part naming
    NULL, -- index ID
    NULL, -- partition ID
    'DETAILED'); -- scan mode
    GO

    你會得到如下報錯信息:

    消息 102,級別 15,狀態 1,第 3 行
    '(' 附近有語法錯誤。

    看上去這足以證明80兼容模式不支持DMV。但其實并不是那樣。

    編者:寫到這里之后,我突然意識到我陷入了一個悖論。DMV在80兼容模式下是完全支持的,但不支持的是在80兼容模式下調用函數作為DMV的參數。

    下面是一個可以在80兼容模式下使用函數作為DMV參數的技巧,不得不說是神來之筆。那就是在一個90以上兼容模式的數據庫下額外調用80兼容模式下的數據庫,看下面代碼:

    USE master
    SELECT * FROM sys.dm_db_index_physical_stats (
    DB_ID ('DMVTest'),-- database ID
    OBJECT_ID ('DMVTest..t1'), -- object ID <<<<<< Note I'm using 3-part naming here now
    NULL,-- index ID
    NULL,-- partition ID
    'DETAILED');-- scan mode
    GO

    雖然DMVTest數據庫工作在80兼容模式下,但上述代碼依然可用。

    但是有一點值得注意的是,你一定要保證Object參數的正確,如果你僅僅讓第二個參數還是OBJECT_ID ('t1'), 那么這個函數會嘗試在Master數據庫中找表t1,正常來說這就會返回NULL,這就導致剛才那個DMV以NULL作為參數,從而返回了所有DMVTest表下的索引狀態.而如果Master表中也有一個DMV,那就更不幸了,你將得到錯誤的信息。

    還有,sys.dm_db_index_physical_stats并不算是一個真正的DMV,而是一個在后臺處理大量信息后返回相關信息的DMF,因此如果你以NULL作為參數返回所有的索引信息的話,那代價會非常高昂,你可以看我最近的博文Inside sys.dm_db_index_physical_stats,這篇文章會對細節和代價進行詳細的解釋。

    還有一種在80兼容模式下使用DMV的方式是不再DMV中以函數作為參數,而是傳變量進去,代碼如下:

    DECLARE @databaseID INT;
    DECLARE @objectID INT;

    SELECT @databaseID = DB_ID ('DMVTest');
    SELECT @objectID = OBJECT_ID ('t1');

    SELECT * FROM sys.dm_db_index_physical_stats (
    @dbid, -- database ID
    @objid, -- object ID
    NULL, -- index ID
    NULL, -- partition ID
    'DETAILED'); -- scan mode
    GO

    嗯,又揭示了一個誤區。

    發表評論 共有條評論
    用戶名: 密碼:
    驗證碼: 匿名發表
    亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
    国产精品老女人精品视频| 国产成人jvid在线播放| 91在线视频导航| 日本韩国欧美精品大片卡二| 国产区精品在线观看| 久久久av一区| 欧美黑人极品猛少妇色xxxxx| 6080yy精品一区二区三区| 成人黄色av播放免费| 亚洲精品久久久久久久久久久久久| 亚洲自拍偷拍第一页| 亚洲成人精品久久久| 久久露脸国产精品| 欧美孕妇毛茸茸xxxx| 国产香蕉精品视频一区二区三区| 欧美性生交xxxxx久久久| 欧美日韩成人免费| 久久夜色精品国产亚洲aⅴ| 久久亚洲一区二区三区四区五区高| 美女av一区二区| 日韩精品高清在线观看| 国产在线精品成人一区二区三区| 91精品一区二区| 欧美黑人一区二区三区| 欧美性高跟鞋xxxxhd| 色综合久久中文字幕综合网小说| 88国产精品欧美一区二区三区| 成人h视频在线| 国产精品1区2区在线观看| 中文字幕日韩在线观看| 久久精品欧美视频| 亚洲国产精品视频在线观看| 久久精品99久久久久久久久| 中文字幕欧美在线| 亚洲美女自拍视频| 中文字幕少妇一区二区三区| 精品自在线视频| 精品一区二区三区四区在线| 亚洲美女精品成人在线视频| 中文字幕一精品亚洲无线一区| 亚洲日韩第一页| 国产精品丝袜白浆摸在线| 91精品久久久久久久久中文字幕| 国产综合色香蕉精品| 久久久久久久电影一区| 在线性视频日韩欧美| 亚洲男女自偷自拍图片另类| 久久久人成影片一区二区三区观看| 午夜精品三级视频福利| 成人性生交大片免费看小说| 亚洲精品国产综合区久久久久久久| 91久久精品日日躁夜夜躁国产| 亚洲国产精品va在看黑人| 国产亚洲精品综合一区91| 亚洲国产天堂网精品网站| 岛国视频午夜一区免费在线观看| 久久伊人精品天天| 在线观看日韩www视频免费| 国语自产精品视频在线看抢先版图片| 欧美大全免费观看电视剧大泉洋| 亚洲福利视频专区| 一本色道久久综合亚洲精品小说| 91久久久在线| 欧美一级黄色网| 91av视频在线观看| 97国产精品免费视频| 亚洲精品电影网在线观看| 久久艳片www.17c.com| 黄色一区二区三区| www国产亚洲精品久久网站| 日韩欧美在线视频| 亚洲成人在线视频播放| 91在线视频导航| 色偷偷888欧美精品久久久| 国产精品福利网站| 国产一区二区三区视频| 国产第一区电影| 久久夜精品va视频免费观看| 国产精品高潮视频| 日韩av成人在线观看| 91禁外国网站| 日韩成人av一区| 精品少妇v888av| 国产精品视频最多的网站| 国产精品爽爽爽| 欧美老女人性生活| 尤物精品国产第一福利三区| 国产日韩精品综合网站| 亲爱的老师9免费观看全集电视剧| 欧美亚洲视频在线看网址| 日韩免费在线电影| 成人免费淫片aa视频免费| 国产91精品久| 国产色视频一区| 亚洲成色999久久网站| 欧美色播在线播放| 欧美精品免费看| 日韩欧美精品中文字幕| 国产成人精品久久久| 国产视频精品一区二区三区| 国产精品视频午夜| 日韩美女av在线免费观看| 91精品在线一区| 久久精品国产亚洲一区二区| 欧美激情a∨在线视频播放| 亚洲性线免费观看视频成熟| 最近2019好看的中文字幕免费| 亚洲性日韩精品一区二区| 欧美乱大交做爰xxxⅹ性3| 91精品国产色综合| 国产精品综合不卡av| 亚洲人成毛片在线播放| 欧美人与性动交| 国产精品va在线播放| 中文字幕亚洲欧美日韩在线不卡| 日韩精品视频免费| 黑人巨大精品欧美一区二区三区| 久久影视电视剧凤归四时歌| 欧美一级bbbbb性bbbb喷潮片| 国产一区在线播放| 欧美精品在线视频观看| 亚洲激情第一页| 亚洲午夜色婷婷在线| 日韩极品精品视频免费观看| 日日噜噜噜夜夜爽亚洲精品| 中文字幕视频一区二区在线有码| 欧美国产日韩在线| 成人精品视频久久久久| 韩国一区二区电影| 欧美日韩日本国产| 国产精品一区二区久久久久| 日韩欧美一区二区在线| 欧美高清视频在线| 欧美精品制服第一页| 日韩中文在线观看| 精品国产一区久久久| 日韩欧美高清在线视频| 亚洲精品永久免费精品| 狠狠综合久久av一区二区小说| 精品国产91久久久久久| 欧美激情一区二区三区在线视频观看| 欧洲亚洲女同hd| 日韩精品视频在线播放| 一本色道久久综合狠狠躁篇的优点| 精品国内亚洲在观看18黄| 久久在线免费观看视频| 国产精品色婷婷视频| 97在线视频免费播放| 日日骚av一区| 麻豆乱码国产一区二区三区| 黑人精品xxx一区| 亚洲少妇中文在线| 国产精品福利在线观看网址| 欧美性资源免费| 国产视频综合在线| 久久免费视频在线观看| 久久韩剧网电视剧| 亚洲成人性视频| 欧美精品精品精品精品免费| 91九色在线视频| 97精品国产97久久久久久免费| 亚洲电影中文字幕| 欧美激情一区二区三区成人| 91精品国产成人www|