MySQL刪除數(shù)據(jù)用法及區(qū)別詳解(DELETE、TRUNCATE?和?DROP)
一、前言
在 MySQL 中,可以使用 DELETE、TRUNCATE 和 DROP 語句來刪除數(shù)據(jù)。這三者雖然都能達(dá)到刪除數(shù)據(jù)的效果,但它們的作用范圍、執(zhí)行效率以及數(shù)據(jù)恢復(fù)能力存在差異。
本文將介紹:
DELETE、TRUNCATE和DROP的用法和區(qū)別DELETE語句的高級用法- 刪除操作的注意事項和最佳實踐
二、MySQL 中的三種刪除方式
1.DELETE語句
DELETE 語句用于刪除表中符合條件的數(shù)據(jù)行,不刪除表本身。
基本語法:
DELETE FROM 表名 WHERE 條件;
表名:要操作的表名稱。WHERE 條件:指定要刪除的記錄,省略則刪除所有記錄。- 不加
WHERE會刪除表中所有數(shù)據(jù),但表結(jié)構(gòu)仍然保留。
示例:
假設(shè)有以下表 users:
CREATE TABLE users (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(50),
age INT,
city VARCHAR(50)
);
-- 插入測試數(shù)據(jù)
INSERT INTO users (name, age, city) VALUES
('Alice', 25, 'Beijing'),
('Bob', 30, 'Shanghai'),
('Charlie', 35, 'Guangzhou');
刪除指定行:
DELETE FROM users WHERE name = 'Bob';
? 結(jié)果:刪除 name='Bob' 的記錄。
刪除所有數(shù)據(jù):
DELETE FROM users;
? 結(jié)果:清空表中數(shù)據(jù),但表結(jié)構(gòu)還在。
刪除多行:
DELETE FROM users WHERE age > 25;
? 結(jié)果:刪除所有年齡大于 25 歲的用戶。
2.TRUNCATE語句
TRUNCATE 語句用于清空表中的所有數(shù)據(jù),但不會記錄刪除操作,效率比 DELETE 更高。
基本語法:
TRUNCATE TABLE 表名;
- 作用:清空表中的數(shù)據(jù),但保留表結(jié)構(gòu)。
- 效率:比
DELETE快,且釋放表空間。 - 自增 ID 重置:
TRUNCATE會將AUTO_INCREMENT重置為 1。
示例:
TRUNCATE TABLE users;
? 結(jié)果:
- 清空表數(shù)據(jù)。
id自動增長重置為 1。
3.DROP語句
DROP 語句用于刪除表本身,不僅數(shù)據(jù)被刪除,表結(jié)構(gòu)也會消失。
基本語法:
DROP TABLE 表名;
- 作用:刪除表及其數(shù)據(jù),無法恢復(fù)。
- 效率:速度快,但不可恢復(fù)。
示例:
DROP TABLE users;
? 結(jié)果:
- 表
users被刪除,數(shù)據(jù)和表結(jié)構(gòu)都不存在。
三、DELETE高級用法
1. 使用DELETE刪除多表數(shù)據(jù)(多表關(guān)聯(lián)刪除)
在多表關(guān)聯(lián)查詢時,可以使用 JOIN 刪除多個表中的數(shù)據(jù)。
基本語法:
DELETE 表別名 FROM 表1 AS 別名1 JOIN 表2 AS 別名2 ON 關(guān)聯(lián)條件 WHERE 條件;
示例:
假設(shè)有以下兩張表:
orders(訂單表)customers(客戶表)
CREATE TABLE customers (
customer_id INT PRIMARY KEY,
name VARCHAR(50)
);
CREATE TABLE orders (
order_id INT PRIMARY KEY,
customer_id INT,
amount DECIMAL(10,2),
FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
);
-- 插入數(shù)據(jù)
INSERT INTO customers VALUES (1, 'Alice'), (2, 'Bob'), (3, 'Charlie');
INSERT INTO orders VALUES (1, 1, 100.50), (2, 2, 200.75), (3, 3, 300.25);
刪除與Bob相關(guān)的訂單:
DELETE o FROM orders o JOIN customers c ON o.customer_id = c.customer_id WHERE c.name = 'Bob';
? 結(jié)果:
- 刪除
Bob相關(guān)的訂單數(shù)據(jù)。
2. 使用LIMIT限制刪除條數(shù)
在刪除大量數(shù)據(jù)時,可以使用 LIMIT 限制刪除的行數(shù),防止誤操作導(dǎo)致大量數(shù)據(jù)丟失。
基本語法:
DELETE FROM 表名 WHERE 條件 LIMIT N;
示例:
刪除 users 表中的前兩條記錄:
DELETE FROM users ORDER BY id ASC LIMIT 2;
? 結(jié)果:
- 僅刪除兩條數(shù)據(jù),防止誤刪大量數(shù)據(jù)。
3. 使用ORDER BY和LIMIT
在刪除數(shù)據(jù)時,可以通過 ORDER BY 和 LIMIT 指定刪除順序和數(shù)量。
示例:
刪除年齡最大的 2 個用戶:
DELETE FROM users ORDER BY age DESC LIMIT 2;
? 結(jié)果:
- 刪除年齡最大的兩名用戶。
四、DELETE與TRUNCATE的區(qū)別
| 對比項 | DELETE | TRUNCATE |
|---|---|---|
| 數(shù)據(jù)刪除方式 | 按行刪除 | 整表清空 |
| 是否記錄日志 | 記錄日志 | 不記錄日志 |
| 自增 ID 重置 | 不重置 | 重置為 1 |
| 刪除速度 | 慢,逐行刪除 | 快,清空整表 |
| 是否可回滾 | 可回滾(開啟事務(wù)) | 不可回滾 |
| 觸發(fā)器是否執(zhí)行 | 會觸發(fā) | 不會觸發(fā) |
| 表空間釋放 | 不釋放 | 釋放表空間 |
五、刪除操作的注意事項
謹(jǐn)慎使用 DELETE 和 TRUNCATE
TRUNCATE無法回滾,清空數(shù)據(jù)前要三思。- 在執(zhí)行刪除前,最好使用
SELECT確認(rèn)數(shù)據(jù)范圍。
使用事務(wù)防止誤操作
- 在執(zhí)行大批量刪除時,使用事務(wù)以便回滾:
START TRANSACTION; DELETE FROM users WHERE age > 30; ROLLBACK; -- 撤銷操作 COMMIT; -- 確認(rèn)操作
備份數(shù)據(jù)
- 刪除操作前,備份重要數(shù)據(jù),以防誤刪。
六、總結(jié)
在 MySQL 中,刪除數(shù)據(jù)主要使用以下三種方式:
- ?
DELETE:按條件刪除數(shù)據(jù),記錄日志,可回滾。 - ?
TRUNCATE:清空表數(shù)據(jù),不記錄日志,不可回滾。 - ?
DROP:刪除表及數(shù)據(jù),無法恢復(fù)。
高級用法:
- 使用
LIMIT限制刪除條數(shù),防止誤刪大量數(shù)據(jù)。 - 多表關(guān)聯(lián)刪除,提高操作靈活性。
- 使用事務(wù)保護數(shù)據(jù),防止誤刪不可恢復(fù)。
到此這篇關(guān)于MySQL刪除數(shù)據(jù)用法及區(qū)別的文章就介紹到這了,更多相關(guān)MySQL刪除數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決ERROR?2003?(HY000):?Can‘t?connect?to?MySQL?server?
在Windows系統(tǒng)上使用Django連接Ubuntu虛擬機中的MySQL數(shù)據(jù)庫時,遇到無法連接的問題,排查后發(fā)現(xiàn)是由于MySQL綁定的IP地址改變導(dǎo)致的,下面就來介紹一下問題解決,感興趣的可以了解一下2024-09-09
mysql通過group?by分組取最大時間對應(yīng)數(shù)據(jù)的兩種有效方法
日常開發(fā)當(dāng)中,經(jīng)常會遇到查詢分組數(shù)據(jù)中指定的記錄,下面這篇文章主要給大家介紹了關(guān)于mysql通過group?by分組取最大時間對應(yīng)數(shù)據(jù)的兩種有效方法,文章通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09
MySQL統(tǒng)計今日生成create_time的數(shù)據(jù)量的方法小結(jié)
create_time通常是一個用于表示某個實體或事件創(chuàng)建時間的字段,在數(shù)據(jù)庫設(shè)計、日志記錄或許多軟件系統(tǒng)中常見,它存儲的是一個日期或時間戳,記錄了數(shù)據(jù)首次被創(chuàng)建的具體時刻,本文介紹了MySQL統(tǒng)計今日生成create_time的數(shù)據(jù)量的方法,需要的朋友可以參考下2024-08-08
mysql密碼忘記后如何修改密碼(2022年最新版詳細(xì)教程保姆級)
因為長時間不操作mysql而忘記root密碼的朋友估計不在少數(shù),下面這篇文章主要給大家介紹了關(guān)于mysql密碼忘記后如何修改密碼的相關(guān)資料,本教程是2022年最新版詳細(xì)教程保姆級,需要的朋友可以參考下2022-04-04
mysql創(chuàng)建Bitmap_Join_Indexes中的約束與索引
現(xiàn)象:創(chuàng)建Bitmap Join Indexes時出現(xiàn)ORA-25954報錯: 維的主鍵或唯一約束條件缺失。 53vi.Com 原因:受到約束與索引的影響。2008-04-04
從云數(shù)據(jù)遷移服務(wù)看MySQL大表抽取模式的原理解析
這篇文章主要介紹了從云數(shù)據(jù)遷移服務(wù)看MySQL大表抽取模式的原理解析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-02
MySQL SUM()帶條件的求和方法與多條件的求和方法解讀
這篇文章主要介紹了MySQL SUM()帶條件的求和方法與多條件的求和方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05

