清空SQL Server資料庫中所有表資料的方法

來源:互聯網
上載者:User

標籤:style   blog   http   ar   color   使用   sp   for   資料   

原文: 清空SQL Server資料庫中所有表資料的方法

其實刪除資料庫中資料的方法並不複雜,為什麼我還要多此一舉呢,一是我這裡介紹的是刪除資料庫的所有資料,因為資料之間可能形成相互約束關係,刪除操作可能陷入死迴圈,二是這裡使用了微軟未正式公開的sp_MSForEachTable預存程序。

  也許很多讀者朋友都經曆過這樣的事情:要在開發資料庫基礎上清理一個空庫,但由於對資料庫結構缺乏整體瞭解,在刪除一個表的記錄時,刪除不了,因為可能有外鍵約束,一個常見的資料庫結構是一個主表,一個子表,這種情況下一般都得先刪除子表記錄,再刪除主表記錄。

  說道刪除資料記錄,往往馬上會想到的是delete和truncate語句,但在遇到在兩個或多個表之間存在約束的話,這兩個語句可能都會失效,而且最要命的是這兩個命令都只能一次操作一個表。那麼真正遇到要刪除SQL Server資料庫中所有記錄時,該怎麼辦呢?有兩個選擇:

  1.按照先後順序逐個刪除,這個方法在表非常多的情況下顯得很不現實,即便是表數量不多,但約束比較多時,你還是要花費大量的時間和精力去研究其間的約束關係,然後找出先刪哪個表,再刪哪個表,最後又刪哪個表。

  2.禁用所有約束,刪除所有資料,最後再啟用約束,這樣就不用花時間和精力去研究什麼約束了,只需要編寫一個簡單的預存程序就可以自動完成這個任務。

CREATE PROCEDURE sp_DeleteAllData
AS
EXEC sp_MSForEachTable ‘ALTER TABLE ? NOCHECK CONSTRAINT ALL‘
EXEC sp_MSForEachTable ‘ALTER TABLE ? DISABLE TRIGGER ALL‘
EXEC sp_MSForEachTable ‘DELETE FROM ?‘
EXEC sp_MSForEachTable ‘ALTER TABLE ? CHECK CONSTRAINT ALL‘
EXEC sp_MSForEachTable ‘ALTER TABLE ? ENABLE TRIGGER ALL‘
EXEC sp_MSFOREACHTABLE ‘SELECT * FROM ?‘
GO

  從這兩個選擇中不難看出第二個選擇是最簡單有效了,那麼在使用第二個選擇時,具體該怎麼實施呢?

  首先得編寫代碼迴圈檢查所有的表,這裡我推薦一個預存程序sp_MSForEachTable,因為在微軟的官方文檔中沒有對這個預存程序有描述,很多開發人員也許都還未曾聽說,所以你在互連網上搜尋得到的解決辦法大多很複雜,也許有的人會認為,既然沒有官方文檔,這個預存程序可能會不穩定,打心理上會排斥它,但事實並非如此。下面來先看一個完整的指令碼:

  這個指令碼建立了一個命名為sp_DeleteAllData的預存程序,前面兩行語句分別禁用約束和觸發器,第三條語句才是真正地刪除所有資料,接下裡的語句分別還原約束和觸發器,最後一條語句是顯示每個表中的記錄,當然這條語句也可以不要,我只是想確認一下是否清空了所有表而已。

  你可以在任何資料庫上運行這個預存程序,當然不要在產生資料庫上運行,可別怪我沒告訴你!不管怎樣,還是先備份一下資料庫,使用備份資料庫還原,然後再運行該預存程序,呵呵,即使是一個大型資料庫,也要不多長時間,你的資料庫就成一個空庫了

清空SQL Server資料庫中所有表資料的方法

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.