MySQL跨表更新 多表update sql语句总结
2022-11-12 09:28:04
内容摘要
这篇文章主要为大家详细介绍了MySQL跨表更新 多表update sql语句总结,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!假定我们有两张表,一
文章正文
这篇文章主要为大家详细介绍了MySQL跨表更新 多表update sql语句总结,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
假定我们有两张表,一张表为Product表存放产品信息,其中有产品价格列Price;另外一张表是ProductPrice表,我们要将ProductPrice表中的价格字段Price更新为Price表中价格字段的80%。在Mysql中我们有几种手段可以做到这一点,一种是update table1 t1, table2 ts ...的方式:代码如下:
1 2 3 4 5 6 | <code> UPDATE product p, productPrice pp SET pp.price = pp.price * 0.8 WHERE p.productId = pp.productId AND p.dateCreated < '2004-01-01' </code> |
代码如下:
1 2 3 4 5 6 7 | <code> UPDATE product p INNER JOIN productPrice pp ON p.productId = pp.productId SET pp.price = pp.price * 0.8 WHERE p.dateCreated < '2004-01-01' </code> |
代码如下:
1 2 3 4 5 6 7 | <code> UPDATE product p LEFT JOIN productPrice pp ON p.productId = pp.productId SET p.deleted = 1 WHERE pp.productId IS null </code> |
代码如下:
1 2 3 4 5 6 7 8 | <code> UPDATE product p INNER JOIN productPrice pp ON p.productId = pp.productId SET pp.price = pp.price * 0.8, p.dateUpdate = CURDATE() WHERE p.dateCreated < '2004-01-01' </code> |
注:关于MySQL跨表更新 多表update sql语句总结的内容就先介绍到这里,更多相关文章的可以留意
代码注释