當前位置:首頁 » 編程語言 » sql循環刪數據
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

sql循環刪數據

發布時間: 2022-12-31 04:55:02

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中循環刪除數據快還是用in快

不考慮系統性能只考慮速度的話,肯定是IN。一次刪除一批。訪問資料庫只需要訪問一次。
然而鎖表時間跟刪除數據量成正比的。如果是經常需要讀取的表,數據上億級的話恐怕會鎖等待超時。

循環的話讀寫數據N次,但是每次鎖表時長很短,如果優化得好的話基本沒感覺。
所以具體還是看你的數據量與表的重要度。

Ⅲ Sql 如何循環遍歷刪除數據

有while了
還要寫if(@i<0)干嗎?

寫了沒問題
也可以循環的
實在不清楚你腳本有什麼問題
你可以在set @i=@i-1加一句
print @i
自己觀察下

Ⅳ SQL怎麼用DELETE刪除多條數據

1、首先,選擇資料庫。

Ⅳ sql清空表數據的方法

一、sql清空表數據的三種方式:

1、truncate--刪除所有數據,保留表結構,不能撤銷還原

2、delete--是逐行刪除速度極慢,不適合大量數據刪除

3、drop--刪除表,數據和表結構一起刪除,快速

二、語法

truncate table 表名

delete from 表名

delete from 表名 where 列名="value "

drop form 表名

怎麼刪除sql中一整行的數據

1、sql中使用DELETE 語句刪除表中的行。按條件刪除數據的基本語法是「DELETE FROM 表名稱 WHERE 列名稱 = 值」,這里以學生表舉列,學生有姓名(name)和年齡(age)兩列:

Ⅶ sql 根據ID循環刪除行

--可以將字元串分解成行插入到一個表變數
--然後根據ID 刪除要刪除的數據
--
--
--這是以前CSDN大版主鄒建 寫的一個方法,很好很強大
/*
分解公式
將公式按運算分解到表中
*/
declare @str varchar(100)
declare @i int,@str1 varchar(10),@str2 varchar(10)
set @str='1,2,3,4' --要分解的字元串
declare @tb table(num varchar(20),operation varchar(2)) --定義保存結果的表
--公式分拆
set @i=patindex('%[^0-9]%',@str)
while @i>0
begin
select @str1=left(@str,@i-1)
,@str=substring(@str,@i,8000)
,@i=patindex('%[0-9]%',@str)
,@str2=left(@str,@i-1)
,@str=substring(@str,@i,8000)
,@i=patindex('%[^0-9]%',@str)
insert into @tb values(@str1,@str2)
end
if @str<>'' insert into @tb values(@str,'')

--顯示分拆結果
select * from @tb

--刪除就這樣 @tb一定要取個別名
DELETE TabelName
FROM @tb AS TA
WHERE TabelName.ID = TA.ID

以上是SQLSERVER 寫法 希望對你有幫助

Ⅷ 如何清除SQL資料庫中的數據

  1. 單擊開始---->所有程序---->MicrosoftSQLServer2014,選擇SQLServer2014ManagementStudio選項,打開軟體。

2.連接到伺服器窗口中,輸入伺服器名稱,選擇SQLServer身份驗證,輸入登錄名和密碼,連接進入資料庫。

3.在左側對象資源管理器中,展開資料庫選項,找到NewData資料庫。

4.在NewData資料庫上右擊,選擇刪除操作。

5.刪除對象窗口中,選擇刪除資料庫備份和還原歷史記錄信息選項,同時選擇關閉現有連接選項,單擊確定。

6.可以看到,SQLServer中的NewData資料庫已刪除。

7.打開SQLServer安裝目錄中的DATA文件夾,NewData資料庫已沒有了,說明NewData資料庫成功刪除。

(8)sql循環刪數據擴展閱讀:

SQL是StructuredQueryLanguage(結構化查詢語言)的縮寫。SQL是專為資料庫而建立的操作命令集,是一種功能齊全的資料庫語言。在使用它時,只需要發出「做什麼」的命令,「怎麼做」是不用使用者考慮的。SQL功能強大、簡單易學、使用方便,已經成為了資料庫操作的基礎,並且現在幾乎所有的資料庫均支持SQL。

SQL資料庫的數據體系結構基本上是三級結構,但使用術語與傳統關系模型術語不同。在SQL中,關系模式(模式)稱為「基本表」(basetable);存儲模式(內模式)稱為「存儲文件」(storedfile);子模式(外模式)稱為「視圖」(view);元組稱為「行」(row);屬性稱為「列」(column)。名稱對稱如^00100009a^:

SQL包括了所有對資料庫的操作,主要是由4個部分組成:

  1. 數據定義:這一部分又稱為「SQLDDL」,定義資料庫的邏輯結構,包括定義資料庫、基本表、視圖和索引4部分。

  2. 數據操縱:這一部分又稱為「SQLDML」,其中包括數據查詢和數據更新兩大類操作,其中數據更新又包括插入、刪除和更新三種操作。

  3. 數據控制:對用戶訪問數據的控制有基本表和視圖的授權、完整性規則的描述,事務控制語句等。

  4. 嵌入式SQL語言的使用規定:規定SQL語句在宿主語言的程序中使用的規則。


參考資料:IT專家網-微軟SQL