Add helper method to set ProjectionList alias.
This commit is contained in:
parent
038a32b032
commit
392ba63bc5
2 changed files with 82 additions and 0 deletions
|
|
@ -1,5 +1,7 @@
|
||||||
package jet
|
package jet
|
||||||
|
|
||||||
|
import "strings"
|
||||||
|
|
||||||
// Projection is interface for all projection types. Types that can be part of, for instance SELECT clause.
|
// Projection is interface for all projection types. Types that can be part of, for instance SELECT clause.
|
||||||
type Projection interface {
|
type Projection interface {
|
||||||
serializeForProjection(statement StatementType, out *SQLBuilder)
|
serializeForProjection(statement StatementType, out *SQLBuilder)
|
||||||
|
|
@ -27,3 +29,23 @@ func (cl ProjectionList) fromImpl(subQuery SelectTable) Projection {
|
||||||
func (cl ProjectionList) serializeForProjection(statement StatementType, out *SQLBuilder) {
|
func (cl ProjectionList) serializeForProjection(statement StatementType, out *SQLBuilder) {
|
||||||
SerializeProjectionList(statement, cl, out)
|
SerializeProjectionList(statement, cl, out)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// As is used to set aliases of the projection list. alias should be in the form 'name' or 'name.*'.
|
||||||
|
// For instance: If projection list has a column 'Artist.Name', and alias is 'Musician.*', returned projection list will
|
||||||
|
// have column wrapped in alias 'Musician.Name'.
|
||||||
|
func (cl ProjectionList) As(alias string) ProjectionList {
|
||||||
|
alias = strings.TrimRight(alias, ".*")
|
||||||
|
|
||||||
|
newProjectionList := ProjectionList{}
|
||||||
|
|
||||||
|
for _, projection := range cl {
|
||||||
|
switch p := projection.(type) {
|
||||||
|
case ProjectionList:
|
||||||
|
newProjectionList = append(newProjectionList, p.As(alias))
|
||||||
|
case ColumnExpression:
|
||||||
|
newProjectionList = append(newProjectionList, newAlias(p, alias+"."+p.Name()))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return newProjectionList
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@ package postgres
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"fmt"
|
||||||
"github.com/go-jet/jet/v2/internal/testutils"
|
"github.com/go-jet/jet/v2/internal/testutils"
|
||||||
. "github.com/go-jet/jet/v2/postgres"
|
. "github.com/go-jet/jet/v2/postgres"
|
||||||
"github.com/go-jet/jet/v2/tests/.gentestdata/jetdb/northwind/model"
|
"github.com/go-jet/jet/v2/tests/.gentestdata/jetdb/northwind/model"
|
||||||
|
|
@ -746,3 +747,62 @@ WHERE not_from_us_or_aus."suppliers.contact_name" != 'John';
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Len(t, dest, 11)
|
require.Len(t, dest, 11)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestWitStatement_CTE_NotMaterialized(t *testing.T) {
|
||||||
|
orders1 := CTE("orders1")
|
||||||
|
orders1ID := Orders.OrderID.From(orders1)
|
||||||
|
orders2 := orders1.ALIAS("orders2")
|
||||||
|
orders2ID := Orders.OrderID.From(orders2)
|
||||||
|
|
||||||
|
stmt := WITH(
|
||||||
|
orders1.AS_NOT_MATERIALIZED(
|
||||||
|
SELECT(
|
||||||
|
Orders.OrderID,
|
||||||
|
Orders.EmployeeID,
|
||||||
|
Orders.ShipCity,
|
||||||
|
).FROM(
|
||||||
|
Orders,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)(
|
||||||
|
SELECT(
|
||||||
|
orders1.AllColumns().As("orders1.*"),
|
||||||
|
orders2.AllColumns().As("orders2.*"),
|
||||||
|
).FROM(
|
||||||
|
orders1.
|
||||||
|
INNER_JOIN(orders2, orders1ID.EQ(orders2ID)),
|
||||||
|
).WHERE(
|
||||||
|
orders1ID.LT(Int(10320)),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
|
||||||
|
// fmt.Println(stmt.Sql())
|
||||||
|
|
||||||
|
testutils.AssertStatementSql(t, stmt, `
|
||||||
|
WITH orders1 AS NOT MATERIALIZED (
|
||||||
|
SELECT orders.order_id AS "orders.order_id",
|
||||||
|
orders.employee_id AS "orders.employee_id",
|
||||||
|
orders.ship_city AS "orders.ship_city"
|
||||||
|
FROM northwind.orders
|
||||||
|
)
|
||||||
|
SELECT orders1."orders.order_id" AS "orders1.order_id",
|
||||||
|
orders1."orders.employee_id" AS "orders1.employee_id",
|
||||||
|
orders1."orders.ship_city" AS "orders1.ship_city",
|
||||||
|
orders2."orders.order_id" AS "orders2.order_id",
|
||||||
|
orders2."orders.employee_id" AS "orders2.employee_id",
|
||||||
|
orders2."orders.ship_city" AS "orders2.ship_city"
|
||||||
|
FROM orders1
|
||||||
|
INNER JOIN orders1 AS orders2 ON (orders1."orders.order_id" = orders2."orders.order_id")
|
||||||
|
WHERE orders1."orders.order_id" < $1;
|
||||||
|
`)
|
||||||
|
|
||||||
|
var dest []struct {
|
||||||
|
Orders1 model.Orders `alias:"orders1.*"`
|
||||||
|
Orders2 model.Orders `alias:"orders2.*"`
|
||||||
|
}
|
||||||
|
|
||||||
|
err := stmt.Query(db, &dest)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Len(t, dest, 72)
|
||||||
|
fmt.Println(len(dest))
|
||||||
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue