欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

postgresql 两表关联更新操作

程序员文章站 2022-03-24 10:44:13
我就废话不多说了,大家还是直接看代码吧~update 要更新的表set 字段1 = cqt.字段1, 字段2 = cqt.字段2,from 数据来源表 cqtwhere 要更新的表.bsm = cqt...

我就废话不多说了,大家还是直接看代码吧~

update 要更新的表
set 字段1 = cqt.字段1,
 字段2 = cqt.字段2,
from
 数据来源表 cqt
where
 要更新的表.bsm = cqt.bsm

补充:postgresql 连表更新字段语法 update

下面这段sql本来目的是想更新条件下的数据,可是这段sql却更新了整个表的数据。sql如下:

update tops_visa.visa_order
set op_audit_abort_pass_date = now()
from
 tops_visa.visa_order as t1
inner join tops_visa.visa_visitor as t2 
on t1. id = t2.order_id
where
 t1.op_audit_abort_pass_date is null
and (
 t2. state = 'pch_abort_op_audit_pass'
 or t2. state = 'pvd_abort_op_audit_pass'
)
 

正确的写法有多种,如下方法也能够实现正确的数据库修改:

update tops_visa.visa_order as t1
set op_audit_abort_pass_date = now()
from
 tops_visa.visa_visitor as t2
where
 t1.id = t2.order_id
and t1.op_audit_abort_pass_date is null
and (
 t2. state = 'pch_abort_op_audit_pass'
 or t2. state = 'pvd_abort_op_audit_pass'
)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。