Ⅰ mysql如何清空表
mysql有兩種方式可以清空表。分別為:delete from 表名和truncate table 表名。
delete from 表名,刪除表數據,全部刪除則是可以清空表,相當於一條條刪除,需要注意的是,如果有欄位是自增的(一般為id),這樣刪除後,id 值還是存在的。舉例來說,就是加入你在刪除之前最大的id為100,你用這種方式清空表後 ,新插入一條數據其id為101,而不是1。
Ⅱ 在SQL中刪除表的內容和刪除表的結構有什麼不同各自用什麼命令語言
區別有以下兩點:
1、定義不同。
刪除表的內容是指刪除表的數據。表的結構還在。
刪除表的結構是指刪除整個表,包括結構和數據。
2、命令不同。
刪除表的內容:
truncate table表名稱;
或者
delete from 表名稱;
刪除表結構:
drop table 表名稱;
(2)sql清空表數據命令擴展閱讀:
truncate:刪除內容、釋放空間但不刪除定義(保留表的數據結構)。truncate 不能刪除行數據,要刪就要把表清空。
delete:delete 語句用於刪除表中的行。delete語句執行刪除的過程是每次從表中刪除一行,並且同時將該行的刪除操作作為事務記錄在日誌中保存,以便進行進行回滾操作。
truncate與不帶where的delete :只刪除數據,而不刪除表的結構(定義)。
如果想保留標識計數值,請改用delete。 如果要刪除表定義及其數據,請使用drop table 語句。
drop:刪除內容和定義,釋放空間。簡單來說就是把整個表去掉。以後是不能新增數據,除非新增一個表。
drop語句將刪除表的結構被依賴的約束(constrain),觸發器(trigger),索引(index);依賴於該表的存儲過程/函數將被保留,但其狀態會變為:invalid。
Ⅲ SQL中怎麼用一條命令把表裡面的數據清零,但是表並沒有刪除
有兩種方法:
1.
重新創建自動編號欄位
2.
用truncate方式刪除表,語法是:truncate
table
表的名字
Ⅳ sql語句中刪除表數據drop、truncate和delete的用法
雖然綠色資源網小編不建議大家去用命令刪除資料庫表中的東西,但是這些刪除命令總有用的著的地方。
說到刪除表數據的關鍵字,大家記得最多的可能就是delete了
然而我們做資料庫開發,讀取資料庫數據.對另外的兩兄弟用得就比較少了
現在來介紹另外兩個兄弟,都是刪除表數據的,其實也是很容易理解的
老大------drop
出沒場合:drop
table
tb
--tb表示數據表的名字,下同
絕招:刪除內容和定義,釋放空間。簡單來說就是把整個表去掉.以後要新增數據是不可能的,除非新增一個表,
例如:一個班就是一個表,學生就是表中的數據,學生的職務就是定義
drop
table
class,就是把整個班移除.學生和職務都消失
比如下面TestSchool資料庫中有兩張表[Classes]表和[Teacher]表
當執行下面代碼之後
Classes表就被清楚,一干二凈!
刪除得非常暴力,作為老大實至名歸
老二-----truncate
出沒場合:truncate
table
tb
絕招:刪除內容、釋放空間但不刪除定義。與drop不同的是,他只是清空表數據而已,他比較溫柔.
同樣也是一個班,他只去除所有的學生.班還在,職務還在,如果有新增的學生可以進去,也可以分配上職務
刪除內容很容易理解,不刪除定義也很容易理解,就是保留表的數據結構
上圖就表現了:刪除內容
執行語句之後,發現數據表的結構還在,也就是不刪除定義
至於釋放空間,看下下面兩幅圖.你們就會明白的
右圖:Id列標識列,因之前delete過行數據,所以會出現標識列不連續(體現了delete刪除是不釋放空間的)
經過truncate
table
Teacher
之後
再新增三條數據
右圖:同樣Id是標識列,發現插入數據的時候,標識列連續了(體現了truncate刪除是釋放空間)
注意:truncate
不能刪除行數據,要刪就要把表清空
老三-----delete
出沒場合:delete
table
tb
--雖然也是刪除整個表的數據,但是過程是痛苦的(系統一行一行地刪,效率較truncate低)
或
delete
table
tb
where
條件
絕招:刪除內容不刪除定義,不釋放空間。三兄弟之中最容易欺負的一個
然後關於delete的就不詳細說明了,大家都懂的
關於truncate的小小總結:
truncate
table
在功能上與不帶
WHERE
子句的
delete語句相同:二者均刪除表中的全部行。
但
truncate
比
delete速度快,且使用的系統和事務日誌資源少。
delete
語句每次刪除一行,並在事務日誌中為所刪除的每行記錄一項。所以可以對delete操作進行roll
back
1、truncate
在各種表上無論是大的還是小的都非常快。如果有ROLLBACK命令Delete將被撤銷,而
truncate
則不會被撤銷。
2、truncate
是一個DDL語言,向其他所有的DDL語言一樣,他將被隱式提交,不能對
truncate
使用ROLLBACK命令。
3、truncate
將重新設置高水平線和所有的索引。在對整個表和索引進行完全瀏覽時,經過
truncate
操作後的表比Delete操作後的表要快得多。
4、truncate
不能觸發任何Delete觸發器。
5、當表被清空後表和表的索引講重新設置成初始大小,而delete則不能。
6、不能清空父表
Ⅳ 150. SQL語言中,刪除表中數據的命令是( )。( ). A.DELETE B.DROP C.
摘要 正確答案是A. DELETE
Ⅵ 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 清空的表的定義與其索引和其他關聯對象一起保留在資料庫中。
Ⅶ delete sql語句是什麼
delete sql語句是用於刪除表中的行的。
從表中刪除行是通過數據操作語言(又稱DML語句)使用delete關鍵字完成的。 到目前為止,SQL刪除操作是所有DML命令中最簡單的操作。 在執行delete命令時不必擔心從表中獲取任何形式的數據,也不必擔心處理從表中獲取的任何數據。
注意:
需要告訴資料庫和表應從何處刪除數據,添加條件子句以設置數據刪除的范圍是一個好主意,否則,它將刪除表中的所有內容。
可能發生的不幸錯誤是意外地運行了不帶Where子句SQL Delete並無意間刪除了所有數據。為防止這種情況發生,請在執行之前考慮使用ApexSQL Complete中的Execution保護功能,以警告此類可能有害的操作。
Ⅷ 清空表應該怎麼寫 SQL
清空所有數據:Truncate Table stu或者Delete stu。
清空第10條以後數據:Delete From Stu Where id Not In、
Select Top 10 id From stu Order By id。
Ⅸ 急呀,怎樣清空SQL資料庫某個表中所有數據用什麼命令可以清除呀
樓上都說使用delete,由於一般要寫日誌,所以速度會慢一些,特別是數據量比較大的時候。樓上更恨,把表給刪了……-__-!!
最簡單而又快速的方法是
truncate table 表名
Ⅹ SQL中刪除表中的內容
(1)如果想清空表裡面的內容可以使用:delete from KF;
(2)如果是想刪除整個表可以使用:drop table KF。
SQL中刪除表中的所有數據的方法:
1、TRUNCATE TABLE 刪除表中的所有行,而不記錄單個行刪除操作。
(1)語法:TRUNCATE TABLE name;
(2)參數 name 是要截斷的表的名稱或要刪除其全部行的表的名稱。
2、DELETE語句,屬於計算機軟體領域,是編程中實現刪除功能的命令。
(1)DELETE語句:用於創建一個刪除查詢,可從列在 FROM 子句之中的一個或多個表中刪除記錄,且該子句滿足 WHERE 子句中的條件,可以使用DELETE刪除多個記錄。
(2)語法:DELETE [table.*] FROM table WHERE criteria;
(3)說明:table參數用於指定從其中刪除記錄的表的名稱。
(4)criteria參數為一個表達式,用於指定哪些記錄應該被刪除的表達式。
(5)可以使用 Execute 方法與一個 DROP 語句從資料庫中放棄整個表。不過,若用這種方法刪除表,將會失去表的結構。不同的是當使用 DELETE,只有數據會被刪除;表的結構以及表的所有屬性仍然保留,例如欄位屬性及索引。
(10)sql清空表數據命令擴展閱讀:
1、SQL 的支持標准:
(1)SQL 是1986年10 月由美國國家標准局(ANSI)通過的資料庫語言美國標准,接著,國際標准化組織(ISO)頒布了SQL正式國際標准。
(2)1989年4月,ISO提出了具有完整性特徵的SQL89標准,1992年11月又公布了SQL92標准,在此標准中,把資料庫分為三個級別:基本集、標准集和完全集。
2、資料庫對象——表格:
(1)資料庫中的表與我們日常生活中使用的表格類似,它也是由行(Row) 和列(Column)組成的。列由同類的信息組成,每列又稱為一個欄位,每列的標題稱為欄位名。
(2)行包括了若干列信息項。一行數據稱為一個或一條記錄,它表達有一定意義的信息組合。一個資料庫表由一條或多條記錄組成,沒有記錄的表稱為空表。每個表中通常都有一個主關鍵字,用於唯一地確定一條記錄。
參考資料來源:
網路-結構化查詢語言
網路-DELETE語句
網路-資料庫對象