[英]Create Update query by joining two tables with github.com/go-pg/pg
我正在尝试通过将某些条件与另一个表连接来更新我的 postgres 表中的一个字段。 我引用了这个链接,它给了我一个与我的场景相关的查询模型:
UPDATE product as p SET price = 200 FROM product_segment as ps WHERE p.segment_id = ps.id and p.name = 'diam'
现在我必须将此查询转换为 orm.Query。 我尝试使用 Join() 但它似乎不起作用。
我试过的代码:
_, err := c.postgresDB.WithContext(ctx).Model(Product).
Set("price =?", 200).
Join("LEFT JOIN product_segment as ps").
JoinOn("ps.id = product.segment_id").
Where("name =?", "diam").
Update()
如何正确编写代码以达到预期的结果???
经过多次尝试,我最终完成了下面的代码,这给了我想要的结果。
_, err := c.postgresDB.WithContext(ctx).Model(Product).
Set("price =? from product_segment as ps", 200).
Where("name =?", "diam").
Update()
如果你们有更好的方法,请分享。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.