刪除sql server資料庫中所有資料
其實刪除資料庫中資料的方法並不複雜,為什麼我還要多此一舉呢,一是我這裡介紹的是刪除資料庫的所有資料,因為資料之間可能形成相互約束關係,刪除操作可能陷入死迴圈,二是這裡使用了微軟未正式公開的sp_MSForEachTable儲存過程。
也許很多讀者朋友都經歷過這樣的事情:要在開發資料庫基礎上清理一個空庫,但由於對資料庫結構缺乏整體瞭解,在刪除一個表的記錄時,刪除不了,因為可能有外來鍵約束,一個常見的資料庫結構是一個主表,一個子表,這種情況下一般都得先刪除子表記錄,再刪除主表記錄。
說 道刪除資料記錄,往往馬上會想到的是delete和truncate語句,但在遇到在兩個或多個表之間存在約束的話,這兩個語句可能都會失效,而且最要命 的是這兩個命令都只能一次操作一個表。那麼真正遇到要刪除SQL Server資料庫中所有記錄時,該怎麼辦呢?有兩個選擇:
1.按照先後順序逐個刪除,這個方法在表非常多的情況下顯得很不現實,即便是表數量不多,但約束比較多時,你還是要花費大量的時間和精力去研究其間的約束關係,然後找出先刪哪個表,再刪哪個表,最後又刪哪個表。
2.禁用所有約束,刪除所有資料,最後再啟用約束,這樣就不用花時間和精力去研究什麼約束了,只需要編寫一個簡單的儲存過程就可以自動完成這個任務。
從這兩個選擇中不難看出第二個選擇是最簡單有效的了,那麼在使用第二個選擇時,具體該怎麼實施呢?
首 先得編寫程式碼迴圈檢查所有的表,這裡我推薦一個儲存過程sp_MSForEachTable,因為在微軟的官方文件中沒有對這個儲存過程有描述,很多開發 人員也許都還未曾聽說,所以你在網際網路上搜尋得到的解決辦法大多很複雜,也許有的人會認為,既然沒有官方文件,這個儲存過程可能會不穩定,打心理上會排斥 它,但事實並非如此。下面來先看一個完整的指令碼:
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_DeleteAllData的儲存過程,前面兩行語句分別禁用約束和觸發器,第三條語句才是真正地刪除所有資料,接下里的語 句分別還原約束和觸發器,最後一條語句是顯示每個表中的記錄,當然這條語句也可以不要,我只是想確認一下是否清空了所有表而已。
你可以在任何資料庫上執行這個儲存過程,當然不要在生成資料庫上執行,可別怪我沒告訴你!不管怎樣,還是先備份一下資料庫,使用備份資料庫還原,然後再執行該儲存過程,呵呵,即使是一個大型資料庫,也要不多長時間,你的資料庫就成一個空庫了,有點怕怕的感覺
也許很多讀者朋友都經歷過這樣的事情:要在開發資料庫基礎上清理一個空庫,但由於對資料庫結構缺乏整體瞭解,在刪除一個表的記錄時,刪除不了,因為可能有外來鍵約束,一個常見的資料庫結構是一個主表,一個子表,這種情況下一般都得先刪除子表記錄,再刪除主表記錄。
說 道刪除資料記錄,往往馬上會想到的是delete和truncate語句,但在遇到在兩個或多個表之間存在約束的話,這兩個語句可能都會失效,而且最要命 的是這兩個命令都只能一次操作一個表。那麼真正遇到要刪除SQL Server資料庫中所有記錄時,該怎麼辦呢?有兩個選擇:
1.按照先後順序逐個刪除,這個方法在表非常多的情況下顯得很不現實,即便是表數量不多,但約束比較多時,你還是要花費大量的時間和精力去研究其間的約束關係,然後找出先刪哪個表,再刪哪個表,最後又刪哪個表。
2.禁用所有約束,刪除所有資料,最後再啟用約束,這樣就不用花時間和精力去研究什麼約束了,只需要編寫一個簡單的儲存過程就可以自動完成這個任務。
從這兩個選擇中不難看出第二個選擇是最簡單有效的了,那麼在使用第二個選擇時,具體該怎麼實施呢?
首 先得編寫程式碼迴圈檢查所有的表,這裡我推薦一個儲存過程sp_MSForEachTable,因為在微軟的官方文件中沒有對這個儲存過程有描述,很多開發 人員也許都還未曾聽說,所以你在網際網路上搜尋得到的解決辦法大多很複雜,也許有的人會認為,既然沒有官方文件,這個儲存過程可能會不穩定,打心理上會排斥 它,但事實並非如此。下面來先看一個完整的指令碼:
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_DeleteAllData的儲存過程,前面兩行語句分別禁用約束和觸發器,第三條語句才是真正地刪除所有資料,接下里的語 句分別還原約束和觸發器,最後一條語句是顯示每個表中的記錄,當然這條語句也可以不要,我只是想確認一下是否清空了所有表而已。
你可以在任何資料庫上執行這個儲存過程,當然不要在生成資料庫上執行,可別怪我沒告訴你!不管怎樣,還是先備份一下資料庫,使用備份資料庫還原,然後再執行該儲存過程,呵呵,即使是一個大型資料庫,也要不多長時間,你的資料庫就成一個空庫了,有點怕怕的感覺
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/16436858/viewspace-627821/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- SQL Server資料庫恢復,SQL Server資料恢復,SQL Server資料誤刪除恢復工具SQLRescueSQLServer資料庫資料恢復
- SQL Server無法刪除資料庫 "xxx",因為該資料庫當前正在使用(如何刪除一個Sql Server資料庫)SQLServer資料庫
- indexedDB 刪除物件倉庫所有資料Index物件
- MS SQL Server 刪除重複行資料SQLServer
- SQL Server中刪除重複資料的幾個方法SQLServer
- SQL Server 查詢資料庫中所有表資料條數SQLServer資料庫
- MongoDB資料庫中更新與刪除資料MongoDB資料庫
- SQL:清空資料庫所有資料SQL資料庫
- SQL刪除資料庫裡所有表的外來鍵,同時刪除所有使用者表SQL資料庫
- Sql Server資料庫資料匯入到SQLite資料庫中Server資料庫SQLite
- 如何刪除資料庫下的所有表(mysql)資料庫MySql
- 在SQL Server資料庫中匯入MySQL資料庫Server資料庫MySql
- SQL2K資料庫開發四之刪除資料庫SQL資料庫
- 刪除資料庫所有使用者表(SqlServer)資料庫SQLServer
- sql server如何刪除前1000行資料SQLServer
- 已為資料庫映象啟動資料庫,必須刪除資料庫映象才能刪除該資料庫資料庫
- SQL Server實戰二:建立、修改、複製、刪除資料庫表並加以資料處理SQLServer資料庫
- Oracle中刪除重複資料的SqlOracleSQL
- SQL SERVER資料庫檔案刪除、分割槽格式化解決方案SQLServer資料庫
- SQL Server實戰一:建立、分離、附加、刪除、備份資料庫SQLServer資料庫
- indexedDB 刪除資料庫Index資料庫
- 在SQL Server資料庫中匯入匯出資料SQLServer資料庫
- 【RAC】刪除RAC資料庫節點(一)——刪除資料庫例項資料庫
- Laravel 資料庫裡的資料刪除Laravel資料庫
- 批量刪除Oracle資料庫的資料Oracle資料庫
- 刪除redo所有日誌,資料庫無法啟動資料庫
- SQL Server資料庫安全SQLServer資料庫
- SQL Server 資料庫映象SQLServer資料庫
- SQL Server 資料庫索引SQLServer資料庫索引
- 資料庫映象 (SQL Server)資料庫SQLServer
- 刪除資料庫中所有儲存過程和函式的sql語句資料庫儲存過程函式SQL
- SQL Server中獲取一個資料庫的所有表的列數SQLServer資料庫
- EM資料庫重建 手動刪除資料庫資料庫
- SQL SERVER收集資料庫使用增量資料SQLServer資料庫
- sql觸發器刪除資料庫中的級聯記錄SQL觸發器資料庫
- 【資料庫資料恢復】Sql Server資料庫資料恢復案例資料庫資料恢復SQLServer
- MongoDB 資料庫建立刪除、表(集合)建立刪除、資料增刪改查MongoDB資料庫
- 2.11 刪除資料庫資料庫