簡體   English   中英

分區表-直接插入還是首先創建臨時表並切換?

[英]Partitioned table - insert directly or create a staging table first and switch in?

關於性能是否相同(或差異可以忽略)? 要插入的數據全部在新分區中。

取決於表上當前的負載,表上的索引-(如果存在未分區的索引,則可能導致問題)。 實際上-取決於。 嘗試測試模擬負載環境。

當前負載影響:

可能需要測試還是可以忽略不計,但是如果表在高插入/更新/讀取負載下,則將數據逐行插入表中將導致大量的短時鎖定,但總的等待時間可能是重大。 因此-切換分區可以顯着減少總體鎖定時間,因為除了集群索引以外,您沒有其他索引

當您嘗試使用除聚簇索引/主鍵之外的過濾器讀取數據子集時,這也會導致死鎖(因為除了聚簇之外,表上沒有任何索引)–這將導致聚簇索引掃描,並且如果存在在此掃描過程中插入/更新的記錄-可能導致死鎖。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM