为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

Go
心有法竹 2022-06-21 16:29:50
我正在尝试在go-pg库中为 golang使用.UnionAll方法。    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    }此代码生成查询:(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))但我希望它是:(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-pg 来获取我期望的原始 SQL 查询呢?问题是由于某种原因我不能将Limit 1表达式应用于整个查询。另外,我的第一个成员Limit 4没有正确应用。union all我的整个代码在这里。
查看完整描述

1 回答

?
慕尼黑的夜晚无繁华

TA贡献1864条经验 获得超6个赞

我相信这个查询对你有用。


if err := db.Model().With("union_q", q0.UnionAll(q1)).Table("union_q").Limit(1).Select(&result); !as.NoError(err) {

    return

}

该查询并不完全是您想要的,据我所知,当前版本的 go-pg 无法生成该查询。但是这个查询正是你想要的。


查看完整回答
反对 回复 2022-06-21
  • 1 回答
  • 0 关注
  • 183 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号