清除sql表中所有資料

2021-05-28 11:51:45 字數 1355 閱讀 5668

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

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

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

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

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

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

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

create procedure sp_deletealldata

a***ec 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的儲存過程,前面兩行語句分別禁用約束和觸發器,第三條語句才是真正地刪除所有資料,接下裡的語句分別還原約束和觸發器,最後一條語句是顯示每個表中的記錄,當然這條語句也可以不要,我只是想確認一下是否清空了所有表而已

mysql刪除表中所有資料

delete from表名 truncate table表名 不帶where 引數的delete 語句可以刪除 mysql 表中所有內容,使用 truncate table 也可以清空 mysql 表中所有內容。效率上truncate 比delete 快,但truncate 刪除後不記錄 mysql...

SQL2008刪除所有資料表指令碼

應用場景 公升級access資料庫到mssql資料庫,id自增需要調整為跟access資料庫中的自增欄位一樣的編號,導致需要不斷的新增記錄跟刪除表重新測試.技術要點 sql游標和變數使用。注意場合 請注意刪除前一定要做資料庫備份,刪除資料後會導致資料庫中所有的資料表和表中的記錄資料丟失,沒備份千萬不...

SQL Server 查詢資料庫中所有資料庫名錶名

1.查詢資料庫中的所有資料庫名 select name from master sysdatabases order by name 2.查詢某個資料庫中所有的表名 select name from sysobjects where xtype u order by name xtype u 表示所...