在 SQLSERVER 中快速有條件刪除海量數(shù)據(jù)
如果你的硬盤空間小,并且不想設(shè)置數(shù)據(jù)庫的日志為最小(因?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)行日志記錄。至今沒有辦法強(qiáng)制制定某一些語句不記錄到日志中,如果在執(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。無論何種恢復(fù)模式都不會(huì)進(jìn)行日志記錄:Truncate table Table1
最后對(duì)Table2進(jìn)行改名為Table1:EC sp_rename 'Table2', 'Table1'
相關(guān)文章
淺述SQL Server的聚焦強(qiáng)制索引查詢條件和Columnstore Index
本文主要講了強(qiáng)制使用索引條件來進(jìn)行查詢,當(dāng)對(duì)于使用默認(rèn)創(chuàng)建索引進(jìn)行查詢計(jì)劃時(shí)覺得不是最優(yōu)解,可以嘗試使用強(qiáng)制索引來進(jìn)行對(duì)比找出更好得解決方案。簡(jiǎn)短的內(nèi)容,深入的理解.有興趣的朋友可以看下2016-12-12SQL性能優(yōu)化之定位網(wǎng)絡(luò)性能問題的方法(DEMO)
這篇文章主要介紹了SQL性能優(yōu)化之定位網(wǎng)絡(luò)性能問題的方法的相關(guān)資料,需要的朋友可以參考下2016-04-04idea連接SQL?Server數(shù)據(jù)庫的詳細(xì)圖文教程
Idea的還有個(gè)強(qiáng)大之處就是連接數(shù)據(jù)庫,就可以少開一個(gè)數(shù)據(jù)庫工具了,下面這篇文章主要給大家介紹了關(guān)于idea連接SQL?Server數(shù)據(jù)庫的詳細(xì)圖文教程,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12數(shù)據(jù)庫日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(1)
下面小編就為大家?guī)硪黄獢?shù)據(jù)庫基礎(chǔ)的幾道練習(xí)題(分享)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧,希望可以幫到你2021-07-07一步步教你建立SQL數(shù)據(jù)庫的表分區(qū)
分區(qū)存儲(chǔ)提高了數(shù)據(jù)庫的性能,被分區(qū)存儲(chǔ)的數(shù)據(jù)物理上是多個(gè)文件,但邏輯上任然是一個(gè)表,對(duì)表的任何操作都跟沒分區(qū)之前一樣。插入、刪除、查詢、更新等操作的時(shí)候,數(shù)據(jù)庫會(huì)自動(dòng)為你找到對(duì)應(yīng)的分區(qū),然后執(zhí)行操作。2015-09-09SQL Server Alwayson添加監(jiān)聽器失敗的解決方法
這篇文章主要為大家詳細(xì)介紹了SQL Server Alwayson添加監(jiān)聽器失敗的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07