如何在 SQL SERVER 中快速有條件刪除海量數(shù)據(jù)
更新時(shí)間:2006年12月21日 00:00:00 作者:
最近有個(gè)朋友問(wèn)我,他說(shuō)他在SQLSERVER刪除幾百萬(wàn)到幾千萬(wàn)數(shù)據(jù)是顯的很慢,幫他分析了一下,提了一些以下意見,或許對(duì)很多人有用。
如果你的硬盤空間小,并且不想設(shè)置數(shù)據(jù)庫(kù)的日志為最小(因?yàn)橄M渌5娜罩鞠M匀挥涗?,而且對(duì)速度要求比較高,并清除所有的數(shù)據(jù)建議你用turncate table1,因?yàn)閠runcate 是DDL操作,不產(chǎn)生rollback,不寫日志速度快一些,然后如果有自增的話,恢復(fù)到1開始,而delete會(huì)產(chǎn)生rollback,如果刪除大數(shù)據(jù)量的表速度會(huì)很慢,同時(shí)會(huì)占用很多的rollback segments,同時(shí)還要記錄下G級(jí)別的日志 ;當(dāng)然如果有條件刪除比如where time〈'2006-3-10' 怎么辦,能不能不記錄日志用delete,回答是不行的,SQL Server 引擎在設(shè)計(jì)上就會(huì)對(duì) Delete 操作進(jìn)行日志記錄。至今沒(méi)有辦法強(qiáng)制制定某一些語(yǔ)句不記錄到日志中,如果在執(zhí)行 Delete Table1 where Time 〈 '2006-3-10' 由于涉及的記錄比較多,所以日志記錄也相應(yīng)很大(3-4G),如果可行,我建議用以下方式:
選出您所需要保留的記錄到新的表。如果您使用 Full Recovery Mode
根據(jù)SELECT INTO的記錄數(shù),日志可能會(huì)比較大
Select * into Table2 From Table1 Where Time 〉 = '2006-03-10'
然后直接Truncate Table1。無(wú)論何種恢復(fù)模式都不會(huì)進(jìn)行日志記錄:Truncate table Table1
最后對(duì)Table2進(jìn)行改名為Table1:EC sp_rename 'Table2', 'Table1'
如果你的硬盤空間小,并且不想設(shè)置數(shù)據(jù)庫(kù)的日志為最小(因?yàn)橄M渌5娜罩鞠M匀挥涗?,而且對(duì)速度要求比較高,并清除所有的數(shù)據(jù)建議你用turncate table1,因?yàn)閠runcate 是DDL操作,不產(chǎn)生rollback,不寫日志速度快一些,然后如果有自增的話,恢復(fù)到1開始,而delete會(huì)產(chǎn)生rollback,如果刪除大數(shù)據(jù)量的表速度會(huì)很慢,同時(shí)會(huì)占用很多的rollback segments,同時(shí)還要記錄下G級(jí)別的日志 ;當(dāng)然如果有條件刪除比如where time〈'2006-3-10' 怎么辦,能不能不記錄日志用delete,回答是不行的,SQL Server 引擎在設(shè)計(jì)上就會(huì)對(duì) Delete 操作進(jìn)行日志記錄。至今沒(méi)有辦法強(qiáng)制制定某一些語(yǔ)句不記錄到日志中,如果在執(zhí)行 Delete Table1 where Time 〈 '2006-3-10' 由于涉及的記錄比較多,所以日志記錄也相應(yīng)很大(3-4G),如果可行,我建議用以下方式:
選出您所需要保留的記錄到新的表。如果您使用 Full Recovery Mode
根據(jù)SELECT INTO的記錄數(shù),日志可能會(huì)比較大
Select * into Table2 From Table1 Where Time 〉 = '2006-03-10'
然后直接Truncate Table1。無(wú)論何種恢復(fù)模式都不會(huì)進(jìn)行日志記錄:Truncate table Table1
最后對(duì)Table2進(jìn)行改名為Table1:EC sp_rename 'Table2', 'Table1'
相關(guān)文章
Spark SQL 中對(duì) Map 類型的操作函數(shù)示例詳解
這篇文章主要介紹了SparkSQL中對(duì)Map類型的操作函數(shù),包括創(chuàng)建、訪問(wèn)、修改、合并、鍵值操作等功能,通過(guò)這些函數(shù),可以方便地進(jìn)行復(fù)雜鍵值對(duì)數(shù)據(jù)的處理,感興趣的朋友跟隨小編一起看看吧2025-01-01
SQL SERVER性能優(yōu)化綜述(很好的總結(jié),不要錯(cuò)過(guò)哦)
一個(gè)系統(tǒng)的性能的提高,不單單是試運(yùn)行或者維護(hù)階段的性能調(diào)優(yōu)的任務(wù),也不單單是開發(fā)階段的事情,而是在整個(gè)軟件生命周期都需要注意,進(jìn)行有效工作才能達(dá)到的。所以我希望按照軟件生命周期的不同階段來(lái)總結(jié)數(shù)據(jù)庫(kù)性能優(yōu)化相關(guān)的注意事項(xiàng)。2008-09-09
SQL Server 服務(wù)由于登錄失敗而無(wú)法啟動(dòng)
當(dāng)域的密碼被修改過(guò)后,相應(yīng)服務(wù)使用的登陸驗(yàn)證信息不會(huì)自動(dòng)更新需要手動(dòng)來(lái)更新,才能解決此問(wèn)題。如果大家嫌比較麻煩,還是像上面的解決方案那樣直接將登陸身份修改為“本地系統(tǒng)帳戶”比較簡(jiǎn)單。2010-05-05

