繁体   English   中英

通过使用 github.com/go-pg/pg 连接两个表来创建更新查询

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM