❶ 如何刪除資料庫中所有數據
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_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的存儲過程,前面兩行語句分別禁用約束和觸發器,第三條語句才是真正地刪除所有數據,接下里的語句分別還原約束和觸發器,最後一條語句是顯示每個表中的記錄,當然這條語句也可以不要,我只是想確認一下是否清空了所有表而已。
你可以在任何資料庫上運行這個存儲過程,當然不要在生成資料庫上運行,可別怪我沒告訴你!不管怎樣,還是先備份一下資料庫,使用備份資料庫還原,然後再運行該存儲過程,呵呵,即使是一個大型資料庫,也要不多長時間,你的資料庫就成一個空庫了
第三種方法: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 清空的表的定義與其索引和其他關聯對象一起保留在資料庫中。
❷ 如何將資料庫中其他的資料庫刪除
當不再需要用戶定義的資料庫,或者已將其移到其他資料庫或伺服器上時,即可刪除該資料庫。Deleting a database(刪除資料庫)與 dropping a database(刪除資料庫)是同義的。資料庫刪除之後,文件及其數據都從伺服器上的磁碟中刪除。資料庫刪除之後,它將被永久刪除,並且如果不使用以前的備份,則無法檢索該資料庫。不能刪除系統資料庫。
可以刪除資料庫,而不管該資料庫所處的狀態。這些狀態包括離線、只讀和可疑。若要顯示資料庫的當前狀態,請使用 sys.databases 目錄視圖。
若要在不刪除文件系統中文件的情況下從當前伺服器上刪除資料庫,請使用 sp_detach_db。
刪除資料庫之後,應備份 master 資料庫,因為刪除資料庫將更新 master 中的信息。如果必須還原 master,自上次備份 master 以來刪除的任何資料庫仍將引用這些不存在的資料庫。這可能導致產生錯誤消息。
前提條件
必須滿足下列條件才能刪除資料庫:
如果資料庫涉及日誌傳送操作,請在刪除資料庫之前取消日誌傳送操作。有關詳細信息,請參閱日誌傳送管理。
若要刪除為事務復制發布的資料庫,或刪除為合並復制發布或訂閱的資料庫,必須首先從資料庫中刪除復制。有關詳細信息,請參閱刪除復制。如果資料庫已損壞,不能首先刪除復制,通常您仍然可以通過首先使用 ALTER DATABASE 將資料庫設置為離線然後再刪除的方法來刪除資料庫。
必須首先刪除資料庫中存在的資料庫快照。有關詳細信息,請參閱資料庫快照。
❸ 如何刪除資料庫操作記錄
使用查詢從資料庫中刪除一條或多條記錄
了解如何使用查詢刪除數據
可以使用兩類查詢來刪除 Access 資料庫中的數據。具體使用哪種查詢取決於要執行的刪除的類型。
* 如果需要刪除一個或多個表中的記錄的個別欄位,您可以使用更新查詢將現有值更改為空值(即不包含數據)或零長度字元串(中間不包含空格的一對雙引號)。
您需要使用更新查詢來刪除個別欄位中的數據,因為在默認情況下,刪除查詢僅刪除整行。使用更新查詢「刪除」數據的過程包含以下主要步驟:創建一個選擇查詢並確保該查詢僅返回您要刪除的數據。然後將此查詢轉換為更新查詢,並使用 NULL 值或零長度字元串作為更新值,再運行查詢以更新現有數據。
* 如果需要刪除整條記錄(行),您可以使用刪除查詢。
默認情況下,刪除查詢將刪除每個欄位中的所有數據,包括唯一標識記錄的鍵值。運行該查詢時,它始終會從表中刪除整個行。此過程包括以下主要步驟:創建一個選擇查詢並確保該查詢返回您要刪除的記錄,然後將此查詢轉換為刪除查詢,並運行該查詢以刪除數據。
進行操作時,請記住:如果要刪除的記錄位於一對多關系的「一」端,必須先更改關系的屬性,然後才能運行查詢,本文後面的准備刪除相關數據一節介紹了如何執行此任務。您還必須進行其他一些更改才能執行刪除操作,因為默認情況下,Access 禁止刪除一對多關系的「一」端中的數據。
如果需要了解有關一對多關系的詳細信息,請參閱文章資料庫設計基礎和創建、編輯或刪除關系。
此外,還請記住:更新或刪除部分或整條記錄後,將不能撤消更改,因此,運行刪除查詢之前,應始終先備份數據。有關詳細信息,請參閱本文後面的備份資料庫。
以下各節中的步驟介紹了如何創建更新查詢以刪除單個欄位中的數據;以及如何創建刪除查詢以刪除整條記錄。
注釋 通常,只有當需要快速更改或刪除大量數據時,才使用更新查詢和刪除查詢。如果只需要刪除少量記錄(便於手動刪除的任何數量),您可以在數據表視圖中打開表,選擇要刪除的欄位或行,然後按 Delete。
有關刪除數據的其他方法的詳細信息,請參閱從資料庫中刪除一條或多條記錄一文。
資料庫中刪除記錄的操作
要使ASP應用程序能夠刪除資料庫表中的現有記錄,一般要完成四個步驟,也就是說刪除頁中必須具有四個構造塊:
①一個用於從資料庫表格中檢索記錄的過濾記錄集(創建記錄集);
②一個要刪除記錄數據的只讀顯示;
③一個將刪除命令發送給伺服器的「提交」按鈕;
④一個更新資料庫表的「刪除記錄」伺服器行為,即對刪除了記錄的資料庫表進行刷新。
刪除頁一次只能包含一個記錄編輯伺服器行為。不能在刪除頁中同時還使用「插入記錄」或「更新記錄」的伺服器行為。
打開「刪除記錄」對話框(如下圖所示),可以通過Dreamweaver8的「插入」菜單來操作,也可以通過Dreamweaver8的「伺服器行為」面板操作。操作步驟類似於資料庫中添加、更新記錄的操作。
此對話框用於將伺服器行為添加到包含HTM表單的頁,以便當用戶單擊表單上的「提交」按鈕時可以在資料庫表中刪除記錄。對話框的設置步驟:
1、在「連接」下拉列表菜單中,選擇一個到資料庫的連接。如果您需要定義連接,則單擊「定義」按鈕。
2、在「從表格中刪除」下拉列表菜單中,選擇包含要刪除的記錄的資料庫表。
3、在「選取記錄自」下拉列表菜單中,指定一個包含要刪除的記錄集。
4、在「唯一鍵列」下拉列表菜單中,選擇一個鍵列(通常是記錄ID列)來標識資料庫表中的記錄。如果該值是一個數字,則選擇「數字」選項。鍵列通常只接受數值,但有時候也接受文本值。
5、在「提交此表單以刪除」彈出菜單中,指定具有將刪除命令發送到伺服器的「提交」按鈕的HTML表單。
6、在「刪除後,轉到」框中,輸入在從資料庫表中刪除記錄後打開的頁或單擊「瀏覽」按鈕瀏覽到該文件。
7、單擊「確定」。
參考:Dreamweaver8幫助
[二00六年八月十四日上午]