博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql 多表 update sql语句总结
阅读量:6272 次
发布时间:2019-06-22

本文共 996 字,大约阅读时间需要 3 分钟。

hot3.png

假定我们有两张表,一张表为Product表存放产品信息,其中有产品价格列Price;

另外一张表是ProductPrice表,我们要将ProductPrice表中的价格字段Price更新为Price表中价格字段的80%。

在Mysql中我们有几种手段可以做到这一点,一种是update table1 t1, table2 ts ...的方式:

UPDATE product p, productPrice ppSET pp.price = pp.price * 0.8WHERE p.productId = pp.productIdAND p.dateCreated < '2004-01-01'

另外一种方法是使用inner join然后更新:

UPDATE product pINNER JOIN productPrice ppON p.productId = pp.productIdSET pp.price = pp.price * 0.8WHERE p.dateCreated < '2004-01-01'

另外我们也可以使用left outer join来做多表update,

比方说如果ProductPrice表中没有产品价格记录的话,

将Product表的isDeleted字段置为1,如下sql语句:

UPDATE product pLEFT JOIN productPrice ppON p.productId = pp.productIdSET p.deleted = 1WHERE pp.productId IS null

另外,上面的几个例子都是两张表之间做关联,但是只更新一张表中的记录,其实是可以同时更新两张表的,如下sql:

UPDATE product pINNER JOIN productPrice ppON p.productId = pp.productIdSET pp.price = pp.price * 0.8,p.dateUpdate = CURDATE()WHERE p.dateCreated < '2004-01-01'

两张表做关联,更新了ProductPrice表的price字段和Product表字段的dateUpdate两个字段。

转载于:https://my.oschina.net/yeahlife/blog/1932811

你可能感兴趣的文章
opencv项目报错_pFirstBlock==pHead解决办法
查看>>
MySQL日志
查看>>
Oracle性能优化之Oracle里的执行计划
查看>>
电脑如何连接远程服务器?听语音
查看>>
使用Xcode 查看objective-C的汇编代码
查看>>
Vue.js——60分钟快速入门
查看>>
设计模式 - 模板方法模式(template method pattern) 具体解释
查看>>
mysql判断一个字符串是否包含某子串 【转】
查看>>
a bad dream
查看>>
FD_CLOEXEC用法及原因_转
查看>>
element UI 的学习一,路由跳转
查看>>
RabbitMQ三种Exchange模式(fanout,direct,topic)的性能比较
查看>>
Spring JavaBean属性值的注入方式( 属性注入, 特殊字符注入 <![CDATA[ 带有特殊字符的值 ]]> , 构造器注入 )...
查看>>
【Linux】Linux下统计当前文件夹下的文件个数、目录个数
查看>>
Hibernate_14_数据连接池的使用
查看>>
Codeforces Round #271 (Div. 2) D. Flowers (递推 预处理)
查看>>
jacky自问自答-java并发编程
查看>>
Struts2+JSON数据
查看>>
zTree实现单独选中根节点中第一个节点
查看>>
Cocos2D-x设计模式发掘之中的一个:单例模式
查看>>