Estoy tratando de usar el método .UnionAll en la biblioteca go-pg para 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 }Este código produce la consulta:
(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) )Pero espero que sea:
(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 Entonces, ¿cómo usar go-pg para obtener una consulta SQL sin formato que espero? El problema es que no puedo aplicar la expresión Limit 1 a toda la consulta por algún motivo. Además, mi Limit 4 no se aplica correctamente a la primera union all miembros. Mi código completo está aquí .
Creo que esta consulta te sirve.
if err := db.Model().With("union_q", q0.UnionAll(q1)).Table("union_q").Limit(1).Select(&result); !as.NoError(err) { return }La consulta no es exactamente lo que querías y, que yo sepa, la versión actual de go-pg no puede generar esa consulta. Pero esta consulta hace exactamente lo que querías.