go -pg UnionAll - ограничить выражение целиком - PullRequest
3 голосов
/ 06 августа 2020

Я пытаюсь использовать метод .UnionAll в go -pg библиотеке для golang.

    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 Ответ

1 голос
/ 09 августа 2020

Я считаю, что этот запрос поможет вам.

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

Запрос не совсем такой, каким вы хотели быть, и, насколько мне известно, текущая версия go -pg может не генерировать этот запрос. Но этот запрос делает именно то, что вы хотели.

...