指令碼:
1create
procedure
sp_deletealldata2as
3exec sp_msforeachtable '
alter table ? nocheck constraint all'4
exec sp_msforeachtable '
alter table ? disable trigger all'5
exec sp_msforeachtable '
delete from ?'6
exec sp_msforeachtable '
alter table ? check constraint all'7
exec sp_msforeachtable '
alter table ? enable trigger all'8
exec sp_msforeachtable '
select * from ?'9
go10
11exec
sp_deletealldata
1213
go14
15drop
procedure sp_deletealldata
方案2:-------------當有約束外來鍵的時候,會出現異常--------------
1.搜尋出所有表名,構造為一條sql語句
declare @trun_name varchar(8000)
set @trun_name=''
select @trun_name=@trun_name + 'truncate table ' + [name] + ' ' from sysobjects where xtype='u' and status > 0
exec (@trun_name)
該方法適合表不是非常多的情況,否則表數量過多,超過字串的長度,不能進行完全清理.
2.利用游標清理所有表
1declare
@trun_name
varchar(50)2
declare name_cursor cursor
for3
select
'truncate table
'+ name from sysobjects where xtype='u
'and status >04
open
name_cursor
5fetch
next
from name_cursor into
@trun_name
6while
@@fetch_status=0
7begin
8exec (@trun_name)9
'truncated table '+
@trun_name
10fetch
next
from name_cursor into
@trun_name
11end
12close
name_cursor
13deallocate name_cursor
----------相關文獻-------------
sql server中清空所有資料表中的記錄
清空所有資料表中的記錄:複製** **如下:
exec sp_msforeachtable @command1 ='truncate table ?'刪除所有資料表:
複製** **如下:
exec sp_msforeachtable 'delete n''?'''清空sql server資料庫中所有表資料的方法(有約束的情況)
其實刪除資料庫中資料的方法並不複雜,為什麼我還要多此一舉呢,一是我這裡介紹的是刪除資料庫的所有資料,因為資料之間可能形成相互約束關係,刪除操作可能陷入死迴圈,二是這裡使用了微軟未正式公開的sp_msforeachtable儲存過程。
也許很多讀者朋友都經歷過這樣的事情:要在開發資料庫基礎上清理乙個空庫,但由於對資料庫結構缺乏整體了解,在刪除乙個表的記錄時,刪除不了,因為可能有外來鍵約束,乙個常見的資料庫結構是乙個主表,乙個子表,這種情況下一般都得先刪除子表記錄,再刪除主表記錄。
說道刪除資料記錄,往往馬上會想到的是delete和truncate語句,但在遇到在兩個或多個表之間存在約束的話,這兩個語句可能都會失效,而且最要命的是這兩個命令都只能一次操作乙個表。那麼真正遇到要刪除sql server資料庫中所有記錄時,該怎麼辦呢?有兩個選擇:
1.按照先後順序逐個刪除,這個方法在表非常多的情況下顯得很不現實,即便是表數量不多,但約束比較多時,你還是要花費大量的時間和精力去研究其間的約束關係,然後找出先刪哪個表,再刪哪個表,最後又刪哪個表。
2.禁用所有約束,刪除所有資料,最後再啟用約束,這樣就不用花時間和精力去研究什麼約束了,只需要編寫乙個簡單的儲存過程就可以自動完成這個任務。
複製** **如下:
create procedure sp_deletealldataasexec 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的儲存過程,前面兩行語句分別禁用約束和觸發器,第三條語句才是真正地刪除所有資料,接下裡的語句分別還原約束和觸發器,最後一條語句是顯示每個表中的記錄,當然這條語句也可以不要,我只是想確認一下是否清空了所有表而已。
你可以在任何資料庫上執行這個儲存過程,當然不要在生成資料庫上執行,可別怪我沒告訴你!不管怎樣,還是先備份一下資料庫,使用備份資料庫還原,然後再執行該儲存過程,呵呵,即使是乙個大型資料庫,也要不多長時間,你的資料庫就成乙個空庫了
第三種方法:truncate table
在sql server資料庫中快速刪除記錄,清空表若要刪除表中的所有行,則 truncate table 語句是一種快速、無日誌記錄的方法。truncate table 與不含有 where 子句的 delete 語句在功能上相同。但是,truncate table 速度更快,並且使用更少的系統資源和事務日誌資源。
與 delete 語句相比,truncate table 具有以下優點:
所用的事務日誌空間較少。
delete 語句每次刪除一行,並在事務日誌中為所刪除的每行記錄一項。truncate table 通過釋放用於儲存表資料的資料頁來刪除資料,並且在事務日誌中只記錄頁釋放。
使用的鎖通常較少。
當使用行鎖執行 delete 語句時,將鎖定表中各行以便刪除。truncate table 始終鎖定表和頁,而不是鎖定各行。
如無例外,在表中不會留有任何頁。
執行 delete 語句後,表仍會包含空頁。例如,必須至少使用乙個排他 (lck_m_x) 表鎖,才能釋放堆中的空表。如果執行刪除操作時沒有使用表鎖,表(堆)中將包含許多空頁。對於索引,刪除操作會留下一些空頁,儘管這些頁會通過後台清除程序迅速釋放。
與 delete 語句相同,使用 truncate table 清空的表的定義與其索引和其他關聯物件一起保留在資料庫中。
清空SQL SERVER資料庫表裡面的資料
今晚國民兄問到關於怎樣清空資料庫裡面資料的問題,以前沒遇過,上google找了一下,發現乙個方法挺好的,於是弄上來大家共享一下,嘿嘿 解決方法 開啟 服務管理器 選中你要處理的資料庫,然後開啟 工具 裡的 sql查分析器 執行下面語句 先禁用所有外來鍵約束 exec sp msforeachtabl...
清空SQL Server資料庫中所有表資料的方法
原文 清空sql server資料庫中所有表資料的方法 其實刪除資料庫中資料的方法並不複雜,為什麼我還要多此一舉呢,一是我這裡介紹的是刪除資料庫的所有資料,因為資料之間可能形成相互約束關係,刪除操作可能陷入死迴圈,二是這裡使用了微軟未正式公開的sp msforeachtable儲存過程。也許很多讀者...
清空SQL Server資料庫中所有表資料的方法
其實刪除資料庫中資料的方法並不複雜,為什麼我還要多此一舉呢,一是我這裡介紹的是刪除資料庫的所有資料,因為資料之間可能形成相互約束關係,刪除操作可能陷入死迴圈,二是這裡使用了微軟未正式公開的sp msforeachtable儲存過程。也許很多讀者朋友都經歷過這樣的事情 要在開發資料庫基礎上清理乙個空庫...