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

MySQL數(shù)據(jù)庫數(shù)據(jù)刪除操作詳解

 更新時間:2022年08月10日 08:19:09   作者:渴望力量的哈士奇  
本文我們將要學(xué)習(xí)的是作為刪除數(shù)據(jù)使用的?“DELETE”?語句,“DELETE”?語句是用來刪除數(shù)據(jù)的,它不能用來刪除數(shù)據(jù)表本身。刪除數(shù)據(jù)表使用的是?“DROP”?語句,而?“DELETE”?的作用只是用來刪除記錄而已

DELETE 語句

DELETE 語句用于刪除記錄,語法如下:(與 “UPDATE” 語法較為相似)

DELETE [IGNORE] FROM 表名
WHERE 條件1, 條件2, .....
ORDER BY ......
LIMIT ......;

-- 使用 IGNORE 關(guān)鍵字時,當(dāng)存在外鍵約束組織我們刪除記錄,那么則會忽略刪除該條數(shù)據(jù)
-- 使用 WHERE 子句刪除條件范圍內(nèi)的記錄;如果不使用 WHERE 子句,則是刪除全表范圍
-- 使用 ORDER BY 關(guān)鍵字,將被刪除的記錄進(jìn)行排序以后,產(chǎn)出符合條件的一些數(shù)據(jù)
-- 使用 LIMIT 關(guān)鍵字依然是分頁的意思,

“DELETE” 語句執(zhí)行的順序:FROM ---> WHERE ---> ORDER BY ---> LIMIT ---> DELETE

DELETE 語句練習(xí)①

刪除 10 部門中,工齡超過 20 年的員工記錄 (這個比較簡單,只涉及到一張表)

DELETE FROM  t_emp 	
WHERE deptno = 10 
AND DATEDIFF(NOW(), hiredate)/365 >= 20;

DELETE 語句練習(xí)②

刪除 20 部門中工資最高的員工記錄(除了使用 WHERE 子句過濾出 20 部門中員工之外,還需要根據(jù)工資 進(jìn)行 降序 排列,并刪除最高的記錄)

DELETE FROM  t_emp 	
WHERE deptno = 20 
ORDER BY sal+IFNULL(comm,0) DESC
LIMIT 1;

"DELETE" 語句的語法還是很簡單的,在有了 "UPDATE" 語句的基礎(chǔ)之后再來看待 "DELETE" 語句就比較好理解了,因為這些子句都差不太多。

DELETE 語句的表連接(內(nèi)連接)

因為相關(guān)子查詢效率非常的低下,所以我們可以利用表連接的方式來提高 DELETE 語句的刪除效率。

“DELETE” SQL語句的內(nèi)連接語法如下:

DELETE 表1, ...... FROM 表1 JOIN 表2 ON 條件
WHERE 條件1, 條件2, ......
ORDER BY ......
LIMIT ......

-- 需要注意的是,這里的 "WHERE"、"ORDER BY"、"LIMIT" 子句都是可選條件

DELETE 語句的表連接練習(xí)①

刪除 SALES 部門和該部門的全部員工記錄

分析:刪除兩張表的記錄

分析:使用 一個 DELETE 語句刪除兩張表記錄,可以使用表連接的方式(參考上文語法)

分析:屬于 SALES 部門的員工記錄未知,需要先試用條件查詢過濾出 SALES 部門的員工記錄

DELETE e, d
FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno
WHERE d.dname="SALES";

DELETE 語句的表連接練習(xí)②

刪除每個低于部門平均底薪的員工記錄

分析:依然使用表連接,因為首先需要去查詢部門進(jìn)行分組,查詢部門的編號與平均底薪。

分析:將查詢到的結(jié)果集作為一張表和 "員工表" 做連接,連接條件就是員工的 "部門編號",還有一個條件就是員工的月薪要低于部門的平均底薪

DELETE e
FROM t_emp e JOIN (SELECT deptno, AVG(sal) AS avg FROM t_emp GROUP BY deptno) t
ON e.deptno=t.deptno 
AND e.sal < t.avg;

DELETE 語句的表連接練習(xí)③

刪除員工 “KING” 和 他的下屬的員工記錄,用表連接來實現(xiàn)

分析:用 "WHERE" 子句查找 "ename" 為 "KING" 的員工記錄

分析:將查到的 "KING" 的員工記錄與員工表的 "mgr" 字段為 "KING" 的 "員工編號" 做連接

DELETE e
FROM t_emp e JOIN (SELECT empno FROM t_emp WHERE ename="KING") t
ON e.mgr=t.empno OR e.empno=t.empno;

DELETE 語句的表連接(外連接)

“DELETE” 語句的表連接既可以是內(nèi)連接,也可以是外連接。

“DELETE” SQL語句的外連接語法如下:

DELETE 表1, ...... FROM 表1 [LEFT | RIGHT] JOIN 表2 ON 條件
WHERE 條件1, 條件2, ......
ORDER BY ......
LIMIT ......

-- 需要注意的是,這里的 "WHERE"、"ORDER BY"、"LIMIT" 子句都是可選條件
-- 除了 在連接表 的時候選擇 "LEFT JOIN" 與 "RIGHT JOIN" 的區(qū)別之外,其他的與內(nèi)連接的語法一樣

DELETE 語句的外連接練習(xí)

刪除 “SALES” 部門的員工,以及沒有部門的員工。

分析:使用 "左外連接" 與 部門表進(jìn)行連接,因為 "員工表" 中的 "張三" 是沒有部門的;所以要保留下來,與部門表進(jìn)行連接。

DELETE e
FROM t_emp e LEFT JOIN t_dept d ON e.deptno=d.deptno
WHERE d.dname="SALES" OR e.deptno IS NULL

速刪除表中的全部數(shù)據(jù)

“DELETE” 語句是在事務(wù)機制下刪除記錄(什么是 “事務(wù)機制” 會在后續(xù)文章詳細(xì)介紹),刪除記錄之前,先要將刪除的記錄保存到日志文件里,然后再刪除記錄。當(dāng)使用 “DELETE” 去刪除海量數(shù)據(jù)的時候,“事務(wù)機制” 會讓刪除的速度變得很慢。

“TRUNCATE” 語句在 “事務(wù)機制” 之外刪除記錄,執(zhí)行速度要遠(yuǎn)遠(yuǎn)地超過 “DELETE” 語句。

“TRUNCATE” 語法如下:

TRUNCATE TABLE 表名;

-- 需要注意的是,"TRUNCATE"  語句一次只能清空一張數(shù)據(jù)表,不能夠一次性的清空多張數(shù)據(jù)表。
TRUNCATE TABLE t_emp ;

MySQL 刪除語句小節(jié)

語句 功能
drop 語句刪除數(shù)據(jù)庫和表
drop 數(shù)據(jù)庫名;
drop 表名;
delete 語句刪除表中的記錄
delete from weibo_user where username=“xiaomu”;
注意:delete語句中如果沒有加入where條件,將會把表中的所有記錄全部刪除
update set 語句修改和更新語句,更新時也會覆蓋(刪除)原來的值
update set與where搭配使用,變更某些記錄
注意::update set語句中如果沒有where子句指定其變更的條件,將就會把數(shù)據(jù)庫中這個字段的所有值都更新
alert 語句刪除字段:alter table 表名 drop 字段名;
刪除主鍵:alter table 表名 drop primary key ;
更新表名:alter table 表名 rename to 新表名;

以上就是MySQL數(shù)據(jù)庫數(shù)據(jù)刪除操作詳解的詳細(xì)內(nèi)容,更多關(guān)于MySQL數(shù)據(jù)刪除的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • MySQL ALTER命令知識點匯總

    MySQL ALTER命令知識點匯總

    在本文中我們給大家整理了關(guān)于MySQL ALTER命令的用法以及相關(guān)知識點內(nèi)容,有興趣的朋友們學(xué)習(xí)下。
    2019-02-02
  • mysql增量備份及恢復(fù)的操作方法

    mysql增量備份及恢復(fù)的操作方法

    增量備份是在全備或上次增量備份基礎(chǔ)上,只備份新增或修改的文件,減少數(shù)據(jù)量和時間,binlog記錄數(shù)據(jù)庫變更,重啟時創(chuàng)建新日志文件,增量備份復(fù)雜但減輕服務(wù)器負(fù)擔(dān),而binlog幫助精確恢復(fù)數(shù)據(jù)
    2023-09-09
  • mysql遷移至8.0時的注意事項(小結(jié))

    mysql遷移至8.0時的注意事項(小結(jié))

    這篇文章主要介紹了mysql遷移至8.0時的注意事項,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • MySQL slave_net_timeout參數(shù)解決的一個集群問題案例

    MySQL slave_net_timeout參數(shù)解決的一個集群問題案例

    這篇文章主要介紹了MySQL slave_net_timeout參數(shù)解決的一個集群問題案例,問題日志請見正文,本文使用slave_net_timeout參數(shù)解決了這個問題,需要的朋友可以參考下
    2015-05-05
  • 自學(xué)MySql內(nèi)置函數(shù)知識點總結(jié)

    自學(xué)MySql內(nèi)置函數(shù)知識點總結(jié)

    在本篇文章里小編給大家整理的是關(guān)于MySql內(nèi)置函數(shù)的知識點總結(jié)內(nèi)容,需要的朋友們可以學(xué)習(xí)參考下。
    2020-01-01
  • MySql 如何實現(xiàn)無則插入有則更新

    MySql 如何實現(xiàn)無則插入有則更新

    這篇文章主要介紹了MySql 實現(xiàn)無則插入有則更新的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 允許遠(yuǎn)程用戶訪問mysql服務(wù)sql語句

    允許遠(yuǎn)程用戶訪問mysql服務(wù)sql語句

    本節(jié)主要介紹了如何允許遠(yuǎn)程用戶訪問mysql服務(wù),本例授權(quán)192.168.14.1 主機的cakephp用戶訪問cakephp數(shù)據(jù)庫
    2014-07-07
  • mysql中distinct和group?by的區(qū)別淺析

    mysql中distinct和group?by的區(qū)別淺析

    distinct簡單來說就是用來去重的,而group by的設(shè)計目的則是用來聚合統(tǒng)計的,兩者在能夠?qū)崿F(xiàn)的功能上有些相同之處,但應(yīng)該仔細(xì)區(qū)分,下面這篇文章主要給大家介紹了關(guān)于mysql中distinct和group?by區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • mysql中redo log和 binlog的區(qū)別

    mysql中redo log和 binlog的區(qū)別

    本文主要介紹了mysql中redo log和 binlog的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • MySQL中replace into與replace區(qū)別詳解

    MySQL中replace into與replace區(qū)別詳解

    本文主要介紹了MySQL中replace into與replace區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08

最新評論