欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL 刪除數(shù)據(jù)詳解(最新整理)

 更新時(shí)間:2025年07月02日 15:25:55   作者:wdwc2  
這篇文章主要介紹了MySQL 刪除數(shù)據(jù)的相關(guān)知識(shí),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧

一、前言

在 MySQL 中,可以使用 DELETE、TRUNCATEDROP 語句來刪除數(shù)據(jù)。這三者雖然都能達(dá)到刪除數(shù)據(jù)的效果,但它們的作用范圍、執(zhí)行效率以及數(shù)據(jù)恢復(fù)能力存在差異。

本文將介紹:

  • DELETE、TRUNCATEDROP 的用法和區(qū)別
  • DELETE 語句的高級用法
  • 刪除操作的注意事項(xiàng)和最佳實(shí)踐

二、MySQL 中的三種刪除方式

1.DELETE語句

DELETE 語句用于刪除表中符合條件的數(shù)據(jù)行,不刪除表本身。

? 基本語法:

DELETE FROM 表名 WHERE 條件;
  • 表名:要操作的表名稱。
  • WHERE 條件:指定要?jiǎng)h除的記錄,省略則刪除所有記錄。
  • 不加 WHERE 會(huì)刪除表中所有數(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ù),但不會(huì)記錄刪除操作,效率比 DELETE 更高。

? 基本語法:

TRUNCATE TABLE 表名;
  • 作用:清空表中的數(shù)據(jù),但保留表結(jié)構(gòu)。
  • 效率:比 DELETE 快,且釋放表空間。
  • 自增 ID 重置TRUNCATE 會(huì)將 AUTO_INCREMENT 重置為 1。

?? 示例:

TRUNCATE TABLE users;

? 結(jié)果:

  • 清空表數(shù)據(jù)。
  • id 自動(dòng)增長重置為 1。

3.DROP語句

DROP 語句用于刪除表本身,不僅數(shù)據(jù)被刪除,表結(jié)構(gòu)也會(huì)消失。

? 基本語法:

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)查詢時(shí),可以使用 JOIN 刪除多個(gè)表中的數(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ù)時(shí),可以使用 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ù)時(shí),可以通過 ORDER BYLIMIT 指定刪除順序和數(shù)量。

?? 示例:

刪除年齡最大的 2 個(gè)用戶:

DELETE FROM users
ORDER BY age DESC
LIMIT 2;

? 結(jié)果:

  • 刪除年齡最大的兩名用戶。

四、DELETE與TRUNCATE的區(qū)別

對比項(xiàng)DELETETRUNCATE
數(shù)據(jù)刪除方式按行刪除整表清空
是否記錄日志記錄日志不記錄日志
自增 ID 重置不重置重置為 1
刪除速度慢,逐行刪除快,清空整表
是否可回滾可回滾(開啟事務(wù))不可回滾
觸發(fā)器是否執(zhí)行會(huì)觸發(fā)不會(huì)觸發(fā)
表空間釋放不釋放釋放表空間

五、刪除操作的注意事項(xiàng)

  1. 謹(jǐn)慎使用 DELETETRUNCATE

    • TRUNCATE 無法回滾,清空數(shù)據(jù)前要三思。
    • 在執(zhí)行刪除前,最好使用 SELECT 確認(rèn)數(shù)據(jù)范圍。
  2. 使用事務(wù)防止誤操作

    • 在執(zhí)行大批量刪除時(shí),使用事務(wù)以便回滾:
    START TRANSACTION;
    DELETE FROM users WHERE age > 30;
    ROLLBACK; -- 撤銷操作
    COMMIT;   -- 確認(rèn)操作
  3. 備份數(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ù)保護(hù)數(shù)據(jù),防止誤刪不可恢復(fù)。

到此這篇關(guān)于MySQL 刪除數(shù)據(jù)詳解的文章就介紹到這了,更多相關(guān)mysql 刪除數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql如何讀寫分離監(jiān)控

    mysql如何讀寫分離監(jiān)控

    本文介紹了如何通過Zookeeper對Mycat節(jié)點(diǎn)進(jìn)行管理和監(jiān)控的詳細(xì)步驟,首先通過tar命令安裝Zookeeper,并配置相關(guān)文件,接著介紹了如何安裝和配置Mycat-web,包括修改配置文件中的IP地址和解決內(nèi)存不足問題
    2024-11-11
  • 盡量避免使用索引合并的場景問題解析

    盡量避免使用索引合并的場景問題解析

    這篇文章主要為大家介紹了盡量避免使用索引合并的場景問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • 為什么MySQL數(shù)據(jù)庫索引選擇使用B+樹?

    為什么MySQL數(shù)據(jù)庫索引選擇使用B+樹?

    今天小編就為大家分享一篇關(guān)于為什么MySQL數(shù)據(jù)庫索引選擇使用B+樹?,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • MySQL查詢條件中in會(huì)用到索引嗎

    MySQL查詢條件中in會(huì)用到索引嗎

    這篇文章主要給大家介紹了MySQL查詢條件中in會(huì)不會(huì)用到索引的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • 深入理解MySQL事務(wù)的4種隔離級別

    深入理解MySQL事務(wù)的4種隔離級別

    本文主要介紹了MySQL事務(wù)的4種隔離級別,事務(wù)的4種隔離級別分別是讀未提交,讀已提交,可重復(fù)讀和串行化,具有一定的參考價(jià)值,感興趣的可以了解一下
    2022-04-04
  • SQL使用復(fù)合索引實(shí)現(xiàn)數(shù)據(jù)庫查詢的優(yōu)化

    SQL使用復(fù)合索引實(shí)現(xiàn)數(shù)據(jù)庫查詢的優(yōu)化

    這篇文章主要介紹了SQL使用復(fù)合索引實(shí)現(xiàn)數(shù)據(jù)庫查詢的優(yōu)化,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-05-05
  • macOS 下的 MySQL 8.0.17 安裝與簡易配置教程圖解

    macOS 下的 MySQL 8.0.17 安裝與簡易配置教程圖解

    這篇文章主要介紹了macOS 下的 MySQL 8.0.17 安裝與簡易配置教程,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • navicat 連接數(shù)據(jù)庫隔段時(shí)間后自動(dòng)斷開連接的解決方案

    navicat 連接數(shù)據(jù)庫隔段時(shí)間后自動(dòng)斷開連接的解決方案

    這篇文章主要介紹了navicat 連接數(shù)據(jù)庫隔段時(shí)間后自動(dòng)斷開連接的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • 基于Php mysql存儲(chǔ)過程的詳解

    基于Php mysql存儲(chǔ)過程的詳解

    本篇文章是對Php中的mysql存儲(chǔ)過程進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • linux mysql 報(bào)錯(cuò):MYSQL:The server quit without updating PID file

    linux mysql 報(bào)錯(cuò):MYSQL:The server quit&nbs

    mysql 報(bào)錯(cuò):MYSQL:The server quit without updating PID file。以下是可能的原因與解決方法
    2013-02-02

最新評論