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

我正在尝试在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我的整个代码在这里。


心有法竹
浏览 184回答 1
1回答

慕尼黑的夜晚无繁华

我相信这个查询对你有用。if err := db.Model().With("union_q", q0.UnionAll(q1)).Table("union_q").Limit(1).Select(&result); !as.NoError(err) {    return}该查询并不完全是您想要的,据我所知,当前版本的 go-pg 无法生成该查询。但是这个查询正是你想要的。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go