开发者

Mysql多表关联更新方式

目录
  • mysql多表关联更新
  • Mysql多表关联update
  • 总结

Mysql多表关联更新

日常的开发中一般都是写的单表update语句,很少写多表关联的update。

在MySQL中我们有几种方法可以做到多表关联更新:

在两编程张表之间做关联,可以更新关联的多张表

update biao1,表2
set 表1.列名=表2编程客栈.列名 --外键或关联字段
where
更新条件;--例如:表1.列名=表2.列名,或字段aa>1等等

通过 INNER JOIN,可以更新关联的多张表

update 表1
inner join 表2  on 表1.列名=表2.列名 --外表链接 ID
set 表1.列名=值;--更新的内容

通过python LEFT JOIN ,可以更新关联的多张表

update 表1
开发者_Elasticsearchleft join 表2 on 表1.列名=表2.列名 --外表链接ID
set 表1.列名=新值;

通过子查询,只更新一张表

update 表1
set 表1.列名=(select 字段 from 表2 where 表2.列名=表1.列名 );

Mysql多表关联update

日常的开发中一般都是写的单表update语句,很少写多表关联的update。

在MySQL中,update的多表连接更新和select的多表连接查询在使用的方法上存在一些小差异。

来看一个具体的例子。

update table1 t1
  inner join table2 t2
    on t1.id = tandroid2.id
set t1.name=t2.name;

在上面的例子中,update关键字后跟的是一个多表关联的结果集,MySQL直接将这个多表关联的结果集看做一个单表,再在这个单表的基础上做常规的update操作。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多python多支持我们。

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新数据库

数据库排行榜