在 SQLSERVER 中快速有條件刪除海量數(shù)據(jù)
如果你的硬盤空間小,并且不想設置數(shù)據(jù)庫的日志為最小(因為希望其他正常的日志希望仍然記錄),而且對速度要求比較高,并清除所有的數(shù)據(jù)建議你用turncate table1,因為truncate 是DDL操作,不產(chǎn)生rollback,不寫日志速度快一些,然后如果有自增的話,恢復到1開始,而delete會產(chǎn)生rollback,如果刪除大數(shù)據(jù)量的表速度會很慢,同時會占用很多的rollback segments,同時還要記錄下G級別的日志 ;當然如果有條件刪除比如where time〈'2006-3-10' 怎么辦,能不能不記錄日志用delete,回答是不行的,SQL Server 引擎在設計上就會對 Delete 操作進行日志記錄。至今沒有辦法強制制定某一些語句不記錄到日志中,如果在執(zhí)行 Delete Table1 where Time 〈 '2006-3-10' 由于涉及的記錄比較多,所以日志記錄也相應很大(3-4G),如果可行,我建議用以下方式:
選出您所需要保留的記錄到新的表。如果您使用 Full Recovery Mode
根據(jù)SELECT INTO的記錄數(shù),日志可能會比較大
Select * into Table2 From Table1 Where Time 〉 = '2006-03-10'
然后直接Truncate Table1。無論何種恢復模式都不會進行日志記錄:Truncate table Table1
最后對Table2進行改名為Table1:EC sp_rename 'Table2', 'Table1'
相關文章
淺述SQL Server的聚焦強制索引查詢條件和Columnstore Index
本文主要講了強制使用索引條件來進行查詢,當對于使用默認創(chuàng)建索引進行查詢計劃時覺得不是最優(yōu)解,可以嘗試使用強制索引來進行對比找出更好得解決方案。簡短的內(nèi)容,深入的理解.有興趣的朋友可以看下2016-12-12SQL性能優(yōu)化之定位網(wǎng)絡性能問題的方法(DEMO)
這篇文章主要介紹了SQL性能優(yōu)化之定位網(wǎng)絡性能問題的方法的相關資料,需要的朋友可以參考下2016-04-04idea連接SQL?Server數(shù)據(jù)庫的詳細圖文教程
Idea的還有個強大之處就是連接數(shù)據(jù)庫,就可以少開一個數(shù)據(jù)庫工具了,下面這篇文章主要給大家介紹了關于idea連接SQL?Server數(shù)據(jù)庫的詳細圖文教程,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2022-12-12一步步教你建立SQL數(shù)據(jù)庫的表分區(qū)
分區(qū)存儲提高了數(shù)據(jù)庫的性能,被分區(qū)存儲的數(shù)據(jù)物理上是多個文件,但邏輯上任然是一個表,對表的任何操作都跟沒分區(qū)之前一樣。插入、刪除、查詢、更新等操作的時候,數(shù)據(jù)庫會自動為你找到對應的分區(qū),然后執(zhí)行操作。2015-09-09SQL Server Alwayson添加監(jiān)聽器失敗的解決方法
這篇文章主要為大家詳細介紹了SQL Server Alwayson添加監(jiān)聽器失敗的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07