佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > 如何在 SQL SERVER 中快速有條件刪除海量數(shù)據(jù)

如何在 SQL SERVER 中快速有條件刪除海量數(shù)據(jù)

熱門標(biāo)簽:AI電銷 Linux服務(wù)器 鐵路電話系統(tǒng) 網(wǎng)站排名優(yōu)化 百度競(jìng)價(jià)排名 服務(wù)外包 呼叫中心市場(chǎng)需求 地方門戶網(wǎng)站
最近有個(gè)朋友問我,他說他在SQLSERVER刪除幾百萬到幾千萬數(shù)據(jù)是顯的很慢,幫他分析了一下,提了一些以下意見,或許對(duì)很多人有用。

    如果你的硬盤空間小,并且不想設(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' 

標(biāo)簽:仙桃 湖南 湘潭 衡水 崇左 蘭州 銅川 黃山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《如何在 SQL SERVER 中快速有條件刪除海量數(shù)據(jù)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    吴忠市| 亚东县| 万山特区| 托克托县| 兴安盟| 手游| 三河市| 临猗县| 类乌齐县| 高州市| 湖州市| 淮北市| 原平市| 陇南市| 象州县| 无锡市| 田林县| 台南县| 高邑县| 上饶县| 内江市| 大理市| 海阳市| 白水县| 宁远县| 新巴尔虎右旗| 龙江县| 许昌市| 昌邑市| 交城县| 牙克石市| 北海市| 闽侯县| 金华市| 三河市| 灵台县| 西平县| 盐山县| 远安县| 凤山县| 乌兰县|