繁体   English   中英

需要将sql-query转换成go-pg orm

[英]Need to convert sql-query into go-pg orm

有一个看起来像这样的查询

   q = 'select distinct t.uuid, t.tags
    from tags as t
    inner join tag_item ti on t.uuid = ti.item_id
    inner join tag_words tw on ti.tag_id = tw.id
    where tw.tag in (?) and ti.item_id in (?)'

如果我使用err:= s.db.QueryContext(ctx, &resp, q, p1, p2)它工作正常

但我并不总是有p1p2所以我希望能够很好地分开它。 我试过这样的事情:

    var resp []*models.TagRecord

    q := s.db.ModelContext(ctx, &resp).ColumnExpr("distinct tags.uuid, tags.tags")
    q = q.Join("inner join tag_item as ti").JoinOn("ti.item_id=tags.uuid")
    if len(filters.UUIDs) != 0 {
        q = q.JoinOn("ti.item_id IN (?)", pg.In(filters.UUIDs))
    }

    q = q.Join("inner join tag_words as tw").JoinOn("tw.id=ti.tag_id")
    if len(filters.Tags) != 0 {
        q = q.JoinOn("tw.tag IN (?)", pg.In(filters.Tags))
    }

    err := q.Select()

但我收到了这个错误:

错误 #42P01 对表“标签”的 FROM 子句条目的引用无效)

我做错了什么,我怎样才能做到这一点?

有一个好主意来记录查询在普通 sql 中的样子,tx to answers to this thread convert go-pg query into plain sql做到了,并想出了如何使上面的代码工作,结果很简单:

var resp []*models.TagRecord

q := s.db.ModelContext(ctx, &resp).ColumnExpr("distinct tag_record.uuid, tag_record.tags")
q = q.Join("inner join tag_item as ti").JoinOn("tag_record.uuid=ti.item_id")
if len(filters.UUIDs) != 0 {
    q = q.JoinOn("ti.item_id IN (?)", pg.In(filters.UUIDs))
}

q = q.Join("inner join tag_words as tw").JoinOn("ti.tag_id=tw.id")
if len(filters.Tags) != 0 {
    q = q.JoinOn("tw.tag IN (?)", pg.In(filters.Tags))
}

err := q.Select()

表标签别名为 tag_record,因此更改了对该别名的调用,并且对 go 都很好)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

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