1、drop (刪除表):刪除內(nèi)容和定義,釋放空間。簡單來說就是把整個表去掉.以后要新增數(shù)據(jù)是不可能的,除非新增一個表。
為岳陽等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及岳陽網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為成都網(wǎng)站制作、網(wǎng)站設計、岳陽網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
drop語句將刪除表的結構被依賴的約束(constrain),觸發(fā)器(trigger)索引(index);依賴于該表的存儲過程/函數(shù)將被保留,但其狀態(tài)會變?yōu)椋篿nvalid。
2、truncate (清空表中的數(shù)據(jù)):刪除內(nèi)容、釋放空間但不刪除定義(保留表的數(shù)據(jù)結構)。與drop不同的是,只是清空表數(shù)據(jù)而已。
注意:truncate 不能刪除行數(shù)據(jù),要刪就要把表清空。
3、delete (刪除表中的數(shù)據(jù)):delete 語句用于刪除表中的行。delete語句執(zhí)行刪除的過程是每次從表中刪除一行,并且同時將該行的刪除操作作為事務記錄在日志中保存以便進行進行回滾操作。
truncate與不帶where的delete :只刪除數(shù)據(jù),而不刪除表的結構(定義)
4、truncate table 刪除表中的所有行,但表結構及其列、約束、索引等保持不變。新行標識所用的計數(shù)值重置為該列的種子。如果想保留標識計數(shù)值,請改用delete。如果要刪除表定義及其數(shù)據(jù),請使用?drop table 語句。
5、對于由foreign key約束引用的表,不能使用truncate table ,而應使用不帶where子句的delete語句。由于truncate table 記錄在日志中,所以它不能激活觸發(fā)器。
6、執(zhí)行速度,一般來說: drop truncate delete。
7、delete語句是數(shù)據(jù)庫操作語言(dml),這個操作會放到 rollback segement 中,事務提交之后才生效;如果有相應的 trigger,執(zhí)行的時候將被觸發(fā)。
擴展資料
例子:
1、查看數(shù)據(jù)庫
2、切換數(shù)據(jù)庫
3、查看數(shù)據(jù)庫中已創(chuàng)建的表
DROP TABLE table_name (刪除表);delete from 表名 where 刪除條件(刪除表內(nèi)數(shù)據(jù),用?delete);truncate table 表名(清除表內(nèi)數(shù)據(jù),保存表結構,用?truncate)。
擴展資料:
1、MySQL中刪除數(shù)據(jù)表是非常容易操作的, 但是你再進行刪除表操作時要非常小心,因為執(zhí)行刪除命令后所有數(shù)據(jù)都會消失。
2、命令提示窗口中刪除數(shù)據(jù)表:SQL語句為?DROP TABLE 。
3、使用PHP腳本刪除數(shù)據(jù)表:PHP使用 mysqli_query 函數(shù)來刪除 MySQL 數(shù)據(jù)表。該函數(shù)有兩個參數(shù),在執(zhí)行成功時返回 TRUE,否則返回 FALSE。語法mysqli_query(connection,query,resultmode)。
4、當你不再需要該表時, 用?drop;當你仍要保留該表,但要刪除所有記錄時, 用?truncate;當你要刪除部分記錄時, 用?delete。
5、drop table table_name?: 刪除表全部數(shù)據(jù)和表結構,立刻釋放磁盤空間,不管是 Innodb 和 MyISAM。實例,刪除學生表:drop table student。
6、truncate table table_name?: 刪除表全部數(shù)據(jù),保留表結構,立刻釋放磁盤空間 ,不管是 Innodb 和 MyISAM。實例,刪除學生表:truncate table student。
7、delete from table_name?: 刪除表全部數(shù)據(jù),表結構不變,對于 MyISAM 會立刻釋放磁盤空間,InnoDB 不會釋放磁盤空間。實例,刪除學生表:delete from student。
8、delete from table_name where xxx?: 帶條件的刪除,表結構不變,不管是 innodb 還是 MyISAM 都不會釋放磁盤空間。實例,刪除學生表中姓名為 "張三" 的數(shù)據(jù):delete from student where T_name = "張三"。
9、delete 操作以后,使用?optimize table table_name?會立刻釋放磁盤空間,不管是 innodb 還是 myisam。實例,刪除學生表中姓名為 "張三" 的數(shù)據(jù):delete from student where T_name = "張三"。
10、delete from?表以后雖然未釋放磁盤空間,但是下次插入數(shù)據(jù)的時候,仍然可以使用這部分空間。
刪除表用drop語句:drop?table?tablename;
解釋:上面語句的意思就是刪除表名為tablename的表。
刪除記錄用delete語句:delete?from?tablename??where??username?=?'123';
解釋:上面語句的意思就是刪除tablename表中username字段的值為123的所有記錄。
備注:drop通常是刪除的對象,delete通常刪除的是某些特定條件下的記錄。
樓主好,數(shù)據(jù)庫清空表使用delete和truncate語句,但這兩個命令語句是有區(qū)別的。首先區(qū)別在于,delete是數(shù)據(jù)庫操作語句而非命令語句,直接清空的是數(shù)據(jù),能夠觸發(fā)觸發(fā)器等操作。而truncate是命令語句,不會觸發(fā)觸發(fā)器等操作,但不能回滾。truncate語句是直接提交的數(shù)據(jù)庫的,而delete是DML語句。delete還會保留數(shù)據(jù)庫的高水線。打個比方,你就能知道最簡單的區(qū)別。比如你的表中有一個自增長的ID,truncate之后,ID會重新開始編碼,但delete會接著你刪除的最大值進行編碼。語法上 delete可以帶where條件,刪除指定數(shù)據(jù),但truncate是不能的,只能全部清空表。下面寫一下兩個語句清空表的語法
delete table
truncate table
sql語言中,刪除一個表的命令是DROPTABLE。
SQL命令是指令,它用于與數(shù)據(jù)庫通信交互。它還用于執(zhí)行特定任務,功能和數(shù)據(jù)查詢。SQL可以執(zhí)行各種任務,如創(chuàng)建表,向表中添加數(shù)據(jù),刪除表,修改表,為用戶設置權限等。sql全稱是結構化查詢語言,即StructuredQueryLanguage,是一種特殊目的的編程語言。
SQL是高級的非過程化編程語言,允許用戶在高層數(shù)據(jù)結構上工作。它不要求用戶指定對數(shù)據(jù)的存放方法,也不需要用戶了解具體的數(shù)據(jù)存放方式,所以具有完全不同底層結構的不同數(shù)據(jù)庫系統(tǒng),可以使用相同的結構化查詢語言作為數(shù)據(jù)輸入與管理的接口。結構化查詢語言語句可以嵌套,這使它具有極大的靈活性和強大的功能。