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

首頁 > 開發 > 綜合 > 正文

對已存在的表進行分區時遇到的坑

2024-07-21 02:46:57
字體:
來源:轉載
供稿:網友
對已存在的表進行分區時遇到的坑

在網上能夠找到很多關于表分區的資料,可是大部分都是在介紹如何給一個新表創建表分區,而對已存在的表如何做分區的文章相對比較少,因此一些坑沒有被“挖掘”出來或者“曝光率”比較低。

筆者最近遇到了一個這樣的案例,剛好踩到了兩個坑,現分享給大家。

對已存在的表進行分區最常見的方法就是重建聚集索引或者創建聚集索引(如果表上沒有)。因為聚集索引的頁級就是實際數據,而重建或者創建聚集索引時會重新組織頁,所以如果在重建或者創建索引時指定分區架構,那么該表上所有的數據就會按照分區架構進行表分區。

在使用此法對表進行分區,有兩個坑請大家注意:

坑一:重建索引時,提示“新的索引定義與現有的索引強制的約束不匹配”

請看如下代碼:

CREATE clustered indexPK_SalesOrderDetail_SalesOrderID_SalesOrderDetailID ON Sales.SalesOrderDetail(SalesOrderID, SalesOrderDetailID) WITH DROP_EXISTINGON [PS_Sod](ModifiedDate)

參數with drop_existing表示給定的索引作為一個事務被刪除和重建;

PK_SalesOrderDetail_SalesOrderID_SalesOrderDetailID是索引的名稱,它建立在表Sales.SalesOrderDetail的SalesOrderID, SalesOrderDetailID字段上;

PS_Sod為分區架構,其參數ModifiedDate表示分區列;

當我執行時,提示錯誤如下:

消息1907,級別16,狀態1,第2 行

無法重新重建索引'PK_SalesOrderDetail_SalesOrderID_SalesOrderDetailID'。新的新的索引定義與現有的索引強制的約束不匹配.

從報錯信息來看,新創建的索引與原索引的約束不匹配,于是執行如下語句,查看當前表身上的約束信息:

SELECT CONSTRAINT_TYPE FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTSWHERE CONSTRAINT_NAME = 'PK_SalesOrderDetail_SalesOrderID_SalesOrderDetailID'

返回的結果為:PRimary

也就是說,當前表上的(SalesOrderID, SalesOrderDetailID)存在主鍵約束,從而確保(SalesOrderID, SalesOrderDetailID)的唯一性,而重建索引時,沒有指定唯一性,因此需要改成如下語句:

CREATE UNIQUE clustered indexPK_SalesOrderDetail_SalesOrderID_SalesOrderDetailID ON Sales.SalesOrderDetail(SalesOrderID, SalesOrderDetailID) WITH DROP_EXISTINGON [PS_Sod](ModifiedDate)

坑二:”唯一索引的分區依據列必須是索引鍵的子集”

即使上述方法修改了執行語句,還是會報錯,只是報錯的內容不再是約束有關,而是唯一索引的分區依據列必須是索引鍵的子集。

消息1908,級別16,狀態1,第2 行

列'ModifiedDate' 是索引'PK_SalesOrderDetail_SalesOrderID_SalesOrderDetailID' 的分區依據列。唯一索引的分區依據列必須是索引鍵的子集。

也就是說,如果要在唯一索引重建時分區,必須要求分區的依據列是唯一索引的一部分。

如此看來,要想通過重建聚集索引的方式對表進行分區,需要滿足如下2個條件中的任意一個:

1. 將分區列添加到索引中;

不過,很多時候分區依據列是datetime類型的字段,作為索引的可選擇性不強,將其添加到索引中并不滿足索引創建的最佳實踐。

2. 索引沒有被顯示標記為unique且不存在主鍵約束;

這樣就不存在唯一索引的說法,也就不需要分區的依據列是唯一索引的一部分;

不過,在實際場景中,如果表的索引在創建時被顯示指定為unique了,還是有辦法通過索引“重建”進行分區的,只不過不能使用在線索引重建的方法,我們必須先手動刪除索引,然后再來創建非unique的索引。這種方式相比with drop_existing重建索引性能要差很多,因為刪除一個聚集索引時,SQL Server必須重建每一個非聚集索引(假設存在非聚集索引),從而將其書簽修改為RID,然后,在創建聚集索引時,又需要將每個非聚集索引的RID更改書簽。而with drop_existing只需要重建一次非聚集索引,當然,如果你在完全相同的鍵上建立索引,非聚集索引根本不需要重建。

至于主鍵約束的限制,相比較而言就比較簡單了,即使表中存在主鍵約束,刪除它時也不會存在性能上的影響。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品久久久精品| 亚洲人成亚洲人成在线观看| 国产在线拍偷自揄拍精品| 欧美日韩美女在线观看| 超碰97人人做人人爱少妇| 欧美日韩在线观看视频小说| 亚洲国产天堂久久综合网| 欧美激情啊啊啊| 三级精品视频久久久久| 久久久99久久精品女同性| 久久久av亚洲男天堂| 日韩精品视频在线观看免费| 久久99精品久久久久久噜噜| 日韩欧美中文字幕在线播放| 亚洲电影中文字幕| 国产欧美精品在线播放| 国产精品第一视频| 疯狂欧美牲乱大交777| 国产精品免费久久久久久| 亚洲欧美国产另类| 国内精品久久久久久中文字幕| 三级精品视频久久久久| 日韩一区视频在线| 欧美精品电影在线| 国产午夜精品理论片a级探花| 国产v综合ⅴ日韩v欧美大片| 亚洲国产91精品在线观看| 51久久精品夜色国产麻豆| 欧美老女人www| 欧美日韩在线视频一区| 国产日韩在线看片| 成人久久18免费网站图片| 久久精品视频中文字幕| 伊人伊成久久人综合网小说| 久久久久这里只有精品| 国产精品露脸av在线| 日韩极品精品视频免费观看| 日韩中文娱乐网| 欧美日韩国产精品一区二区三区四区| 国产精品欧美一区二区三区奶水| 国产日韩欧美中文在线播放| 国产99视频在线观看| 成人免费视频在线观看超级碰| 久久免费国产精品1| 亚洲精品在线观看www| 日韩免费在线观看视频| 国产日韩欧美在线播放| 亚洲香蕉成人av网站在线观看| 欧美亚洲第一页| 欧美日韩亚洲一区二区三区| 青草热久免费精品视频| 欧美性xxxx极品hd满灌| 日韩av在线一区| 国产精品视频一| 亚洲娇小xxxx欧美娇小| 精品毛片网大全| 日韩精品高清在线| 亚洲国产另类 国产精品国产免费| 久久久女女女女999久久| 精品一区二区电影| 日韩av日韩在线观看| 大荫蒂欧美视频另类xxxx| 久久精品亚洲一区| 欧美极品少妇xxxxⅹ免费视频| 亚洲精品国产拍免费91在线| 国内精品久久久久久| 久久影院在线观看| 麻豆一区二区在线观看| 国产精品久久久久久久久久新婚| 亚洲黄色免费三级| 日韩人在线观看| 成人在线播放av| 欧美精品在线极品| 久久影视电视剧免费网站| 中文综合在线观看| 疯狂蹂躏欧美一区二区精品| 国产香蕉精品视频一区二区三区| 欧美性极品少妇精品网站| 亚洲精品av在线播放| 久久婷婷国产麻豆91天堂| 国产日韩欧美在线观看| 91久久久久久久久久| 国产精品一区=区| 亚洲变态欧美另类捆绑| 精品久久久久人成| 欧美激情手机在线视频| 97在线精品国自产拍中文| 欧美激情一级欧美精品| 日韩成人黄色av| 色偷偷噜噜噜亚洲男人的天堂| 国产精品激情av在线播放| 国产精品video| 欧美激情中文字幕乱码免费| 91av在线免费观看| 亚洲人成伊人成综合网久久久| 欧美视频不卡中文| 久久精品99无色码中文字幕| 欧美理论电影在线观看| 国产精品一区av| 日韩精品在线视频美女| 色婷婷av一区二区三区久久| 中文字幕国产日韩| 国产视频精品一区二区三区| 亚洲精品美女久久| 亚洲国产精品va在线看黑人动漫| 中文字幕亚洲二区| 亚洲第一天堂av| 亚洲四色影视在线观看| 亚洲白虎美女被爆操| 精品美女永久免费视频| 色偷偷9999www| 国产欧美一区二区三区在线看| 欧美精品在线观看| 欧美壮男野外gaytube| 成人在线视频网| 91免费精品国偷自产在线| 亚洲一区二区三区成人在线视频精品| 国产精品日韩在线一区| 午夜欧美不卡精品aaaaa| 亚洲第一男人av| 国产精品十八以下禁看| 欧美诱惑福利视频| 欧美激情免费观看| 成人啪啪免费看| 日韩久久精品成人| 精品呦交小u女在线| 欧美精品福利在线| 久久精品国产91精品亚洲| 国产成人精品最新| 国产午夜精品一区理论片飘花| 久久久久这里只有精品| 亚洲精选中文字幕| 欧美成人免费在线观看| 欧美乱人伦中文字幕在线| 欧美在线亚洲一区| 成人网在线免费观看| 国产精品视频久| 福利一区福利二区微拍刺激| 亚洲成人1234| 亚洲成人av中文字幕| 亚洲国产欧美一区二区丝袜黑人| 最近2019年中文视频免费在线观看| 国产精品va在线播放我和闺蜜| 久久精品最新地址| 亚洲国产天堂久久国产91| 欧美一区二区三区艳史| 国产成人精品久久亚洲高清不卡| 亚洲一区第一页| 91精品免费视频| 亚洲欧美制服丝袜| 国产日韩在线一区| 视频直播国产精品| 亚洲欧美综合另类中字| 欧美肥老太性生活视频| 精品亚洲一区二区三区在线播放| 色偷偷综合社区| 久久久久久久影院| 九九热在线精品视频| 欧美裸体xxxxx| www.日韩不卡电影av| 久99久在线视频| 亚洲精品成人久久| 国产精品普通话| 日韩欧美在线第一页|