當前位置:首頁 » 編程語言 » sql刪除資料庫所有表

sql刪除資料庫所有表

發布時間: 2022-06-29 17:28:35

sql..如何用命令刪除資料庫中所有的表

要刪除所有的用戶表:

declare @sql varchar(8000)

SELECT @sql='drop table ' + name
FROM sysobjects
WHERE (type = 'U')
ORDER BY 'drop table ' + name

exec(@sql)

如果要刪除所有用戶表中的內容,可以執行以下語句:

declare @sql varchar(8000)

SELECT @sql='truncate table ' + name
FROM sysobjects
WHERE (type = 'U')
ORDER BY 'truncate table ' + name

exec(@sql)

慎用!

❷ SQL刪除資料庫中的所有數據

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 清空的表的定義與其索引和其他關聯對象一起保留在資料庫中。

❸ sql刪除資料庫所有表

問題問的很雷人。你是說MYSQL還是MSSQL?
但是有個最終解決辦法。
就是:
刪除這個庫。之後從新建立這個庫。不就刪除所有表了嘛。
哈哈。

❹ sql刪除資料庫數據表

ACCESS 用 SQL語句 刪除 數據表;

假設 數據表名 是 「工資表」,用SQL語句 刪除「工資表」可執行下面兩行語句:

SQL = "Drop table 工資表"

DoCmd.RunSQL SQL


當然,也可以用 DAO 刪除數據表,語句如下:

CurrentDb.TableDefs.Delete "工資表"

❺ 將SQL一個資料庫中所有的表中的數據刪除

use
資料庫名
exec
sp_msforeachtable
"drop
table
?"
--這個操作比較危險,刪除該資料庫下的所有表。不知道是不是你要的結果
如果是只刪除數據的話
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
exec
sp_DeleteAllData

❻ 如何刪除sql資料庫中所有的表

有兩種辦法可以刪除表中的所有數據:

1、TRUNCATE TABLE 刪除表中的所有行,而不記錄單個行刪除操作。

語法 TRUNCATE TABLE name
參數 name 是要截斷的表的名稱或要刪除其全部行的表的名稱。

2、Delete from tablename where 1=1

❼ sql語句--刪除資料庫中所有的表

要刪除所有的用戶表: declare @sql varchar(8000) SELECT @sql='drop table ' + name FROM sysobjects WHERE (type = 'U') ORDER BY 'drop table ' + name exec(@sql) 如果要刪除所有用戶表中的內容,可以執行以下語句: declare @sql varchar(8000) SELECT @sql='truncate table ' + name FROM sysobjects WHERE (type = 'U') ORDER BY 'truncate table ' + name exec(@sql) 慎用!

❽ 1.SQL中如何用delete刪除指定表中的所有內容 2.如何刪除所有表

delete
from
table
是根據條件來刪除的,也就是說,你可以根據自己想刪除的記錄的一些特有的條件來刪除它,
一般plsql操作oracle的時候,可以將語句寫成這種格式
select
*
from
table
--delete
from
table
where
a
=
b;
and
c
in
('d','e')
and
f
like
'%g%';
刪除的時候可以從delete開始選中,完全選中就是查看,
如果想刪除所有表,那麼可以使用這種方法(慎用!!!):
用戶下有一個默認的表,all_tables
裡面存儲了所有表的信息,可以通過字元拼接來實現drop語句
select
'drop
table
'||table_name||';'
from
all_tables;
將這些語句執行,那麼就可以刪除所有表,
不過也可以通過select
*
from
all_tables
where
table_name
like
'%abcd%';來查找自己想要刪除卻忘記了表名的一些表。

❾ 用sql 語句怎麼徹底刪除 dbf 資料庫中所有數據。不是僅僅做個刪除標記。

刪除表中的記錄:delete from 表名 where 條件表達式----------標記
pack------------------------------------------將標記的記錄刪除!

❿ sql刪除資料庫所有表應該用哪個命令

use 資料庫名(是要刪除表的所在的那個資料庫的名稱)
GO
declare @sql varchar(8000)
while (select count(*) from sysobjects where type='U')>0
begin
SELECT @sql='drop table ' + name
FROM sysobjects
WHERE (type = 'U')
ORDER BY 'drop table ' + name
exec(@sql)
end-----------------------------------------------use 資料庫一定要填對哦......

熱點內容
關閉ip訪問 發布:2024-04-19 15:59:18 瀏覽:729
大屏安卓系統哪個好 發布:2024-04-19 15:49:10 瀏覽:791
解壓瀏覽器 發布:2024-04-19 15:39:22 瀏覽:574
pythonutfgbk 發布:2024-04-19 15:32:20 瀏覽:221
騰訊雲伺服器搭建網站打不開 發布:2024-04-19 15:32:15 瀏覽:966
光遇腳本輔助下載免費ios 發布:2024-04-19 15:22:11 瀏覽:243
表格VB腳本 發布:2024-04-19 15:13:07 瀏覽:779
python生成器表達式 發布:2024-04-19 15:12:10 瀏覽:747
獲取文件夾文件名 發布:2024-04-19 14:45:51 瀏覽:248
嗶咔本地緩存怎麼看 發布:2024-04-19 14:36:00 瀏覽:106