mysql两个表关联更新问题?

mysql两个表关联更新问题?,第1张

我好像昨天回答过,你不相信可以上机测试:

UPDATE 表1 SET address=(SELECT 表2.address from 表2 WHERE 表2.name=表1.name)

上面的语句非常简单,很容易明白,语句工作时,扫描表1的所有记录,对于每一条记录,按照name去查找表2的address并替换本表此字段。

update t_time t1

set t1.Bks=

(select max(t2.EndTime) from t_diaoyonglian0703 t2

where t1.TraceID=t2.TraceID and t2.Site='bks')-

(select MIN(t2.BeginTime) from t_diaoyonglian0703 t2

where t1.TraceID=t2.TraceID and t2.Site='bks')

where t1.Date='0703'

update gz

set gz.gz_name=gr.gr_name

from gz , gr

where gz.gz_ygid=gr.gr_ygid

这种写法,在 SQL Server 下面可以运行, 在 MySQL 下面是运行不了的。

你可以创建一个 视图,来关联这2个表,然后通过更新 视图的方式,来更新表。

具体的例子,请查看参考资料中的 mysql 的例子代码。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/7232896.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-03
下一篇 2023-04-03

发表评论

登录后才能评论

评论列表(0条)

保存