国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

mysql支持跨表delete刪除多表記錄

2024-07-24 12:48:52
字體:
來源:轉載
供稿:網(wǎng)友
前幾天寫了Mysql跨表更新的一篇總結,今天我們看下跨表刪除。
在Mysql4.0之后,mysql開始支持跨表delete。
Mysql可以在一個sql語句中同時刪除多表記錄,也可以根據(jù)多個表之間的關系來刪除某一個表中的記錄。
假定我們有兩張表:Product表和ProductPrice表。前者存在Product的基本信息,后者存在Product的價格。
第一種跨表刪除的方式是不用join,在delete時指定用半角逗號分隔多個表來刪除,如下sql語句:
復制代碼 代碼如下:

DELETE p.*, pp.*
FROM product p, productPrice pp
WHERE p.productId = pp.productId
AND p.created < '2004-01-01'

第二種跨表刪除的方式是使用inner join在join中指定兩表之間的關聯(lián)關系,如下sql語句:
復制代碼 代碼如下:

DELETE p.*, pp.*
FROM product p
INNER JOIN productPrice pp
ON p.productId = pp.productId
WHERE p.created < '2004-01-01'

注意:跨表刪除不必刪除所有表的數(shù)據(jù),上面的sql語句表會同時刪除Product和ProductPrice兩張表中的數(shù)據(jù),但是你可以指定 DELETE product.*從而只刪除product表中的記錄,而不處理ProductPrice表中的記錄。

跨表刪除也可以使用left join,例如我們要刪除所有在ProductPrice表中沒有記錄的Product表記錄。如下sql語句:
復制代碼 代碼如下:

DELETE p.*
FROM product p
LEFT JOIN productPrice pp
ON p.productId = pp.productId
WHERE pp.productId is null

跨表刪除很有用,在需要的時候就用它吧。歡迎閱讀另外一篇關于跨表更新的介紹文章

您可能感興趣的文章:

完全卸載mysql(停止服務、卸載相關程序、刪除注冊表mysql表的清空、刪除和修改操作詳解MySQL刪除表數(shù)據(jù)的方法MySQL實現(xiàn)快速刪除所有表而不刪除數(shù)據(jù)庫的方法mysql使用教程之分區(qū)表的使用方法(刪除分區(qū)表)MYSQL刪除表中的指定ID數(shù)據(jù)MySQL命令行刪除表中的一個字段MySQL中批量刪除指定前綴表的sql語句MySQL 添加、修改、刪除表的列及約束等表的定義MySQL刪除表時I/O錯誤的原因分析與解決
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 常熟市| 张家港市| 许昌县| 建水县| 城市| 军事| 三门县| 醴陵市| 宁波市| 长丰县| 灵丘县| 扶沟县| 确山县| 鄂州市| 商河县| 蚌埠市| 苍南县| 咸宁市| 四川省| 安远县| 黎川县| 德保县| 凌源市| 莱阳市| 盖州市| 衡东县| 阿拉善右旗| 洛阳市| 揭东县| 济宁市| 柳州市| 天水市| 岳阳县| 彝良县| 佛冈县| 阜康市| 乐清市| 金溪县| 乌拉特后旗| 罗源县| 博罗县|