首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >go-pg UnionAll -限制整个表达式

go-pg UnionAll -限制整个表达式
EN

Stack Overflow用户
提问于 2020-08-06 06:13:10
回答 1查看 222关注 0票数 3

我正在尝试在.UnionAll库中使用围棋方法。

代码语言:javascript
复制
    var model []Customer
    q0 := db.Model(&model).Where("name = ?", name0).Limit(4)
    q1 := db.Model(&model).Where("name = ?", name1).Limit(3)
    var result []Customer
    if err := q0.UnionAll(q1).Limit(1).Select(&result); !as.NoError(err) {
        return
    }

此代码生成查询:

代码语言:javascript
复制
(SELECT "customer"."id", "customer"."name" FROM customers AS "customer" WHERE (name = 'customer 1deificatory zonoid reprepare alacrify serenissime') 
LIMIT 1) 
UNION ALL 
(SELECT "customer"."id", "customer"."name" FROM customers AS "customer" WHERE (name = 'customer 2fordless ferroboron radiability dandizette smutch'
LIMIT 3)
)

但我希望它是:

代码语言:javascript
复制
(SELECT "customer"."id", "customer"."name" FROM customers AS "customer" WHERE (name = 'customer 1deificatory zonoid reprepare alacrify serenissime') 
LIMIT 4) 
UNION ALL 
(SELECT "customer"."id", "customer"."name" FROM customers AS "customer" WHERE (name = 'customer 2fordless ferroboron radiability dandizette smutch')
LIMIT 3)

LIMIT 1

那么,如何使用go来获取我所期望的原始SQL查询呢?问题是,由于某些原因,我无法将Limit 1表达式应用于整个查询。另外,我的Limit 4没有正确地应用于第一个union all成员。我的全部代码是这里

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-08-09 13:41:18

我相信这个查询对你有好处。

代码语言:javascript
复制
if err := db.Model().With("union_q", q0.UnionAll(q1)).Table("union_q").Limit(1).Select(&result); !as.NoError(err) {
    return
}

这个查询不是您想要的,据我所知,当前版本的go无法生成该查询。但这个查询完全符合您的要求。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63277841

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档