jet/mysql/set_statement.go

102 lines
2.9 KiB
Go
Raw Normal View History

2019-08-11 12:13:59 +02:00
package mysql
import "github.com/go-jet/jet/internal/jet"
// UNION effectively appends the result of sub-queries(select statements) into single query.
// It eliminates duplicate rows from its result.
2019-08-17 10:43:16 +02:00
func UNION(lhs, rhs jet.StatementWithProjections, selects ...jet.StatementWithProjections) setStatement {
return newSetStatementImpl(union, false, toSelectList(lhs, rhs, selects...))
2019-08-11 12:13:59 +02:00
}
// UNION_ALL effectively appends the result of sub-queries(select statements) into single query.
// It does not eliminates duplicate rows from its result.
2019-08-17 10:43:16 +02:00
func UNION_ALL(lhs, rhs jet.StatementWithProjections, selects ...jet.StatementWithProjections) setStatement {
return newSetStatementImpl(union, true, toSelectList(lhs, rhs, selects...))
2019-08-11 12:13:59 +02:00
}
2019-08-17 10:43:16 +02:00
type setStatement interface {
setOperators
2019-08-11 12:13:59 +02:00
2019-08-17 10:43:16 +02:00
ORDER_BY(orderByClauses ...jet.OrderByClause) setStatement
2019-08-11 12:13:59 +02:00
2019-08-17 10:43:16 +02:00
LIMIT(limit int64) setStatement
OFFSET(offset int64) setStatement
2019-08-11 12:13:59 +02:00
AsTable(alias string) SelectTable
}
2019-08-17 10:43:16 +02:00
type setOperators interface {
2019-08-11 12:13:59 +02:00
jet.Statement
jet.HasProjections
2019-08-12 10:16:08 +02:00
jet.Expression
2019-08-11 12:13:59 +02:00
2019-08-17 10:43:16 +02:00
UNION(rhs SelectStatement) setStatement
UNION_ALL(rhs SelectStatement) setStatement
2019-08-11 12:13:59 +02:00
}
type setOperatorsImpl struct {
2019-08-17 10:43:16 +02:00
parent setOperators
2019-08-11 12:13:59 +02:00
}
2019-08-17 10:43:16 +02:00
func (s *setOperatorsImpl) UNION(rhs SelectStatement) setStatement {
2019-08-11 12:13:59 +02:00
return UNION(s.parent, rhs)
}
2019-08-17 10:43:16 +02:00
func (s *setOperatorsImpl) UNION_ALL(rhs SelectStatement) setStatement {
2019-08-11 12:13:59 +02:00
return UNION_ALL(s.parent, rhs)
}
type setStatementImpl struct {
jet.ExpressionStatementImpl
setOperatorsImpl
setOperator jet.ClauseSetStmtOperator
}
2019-08-17 10:43:16 +02:00
func newSetStatementImpl(operator string, all bool, selects []jet.StatementWithProjections) setStatement {
2019-08-11 12:13:59 +02:00
newSetStatement := &setStatementImpl{}
newSetStatement.ExpressionStatementImpl.StatementImpl = jet.NewStatementImpl(Dialect, jet.SetStatementType, newSetStatement,
&newSetStatement.setOperator)
newSetStatement.ExpressionStatementImpl.ExpressionInterfaceImpl.Parent = newSetStatement
newSetStatement.setOperator.Operator = operator
newSetStatement.setOperator.All = all
newSetStatement.setOperator.Selects = selects
newSetStatement.setOperator.Limit.Count = -1
newSetStatement.setOperator.Offset.Count = -1
newSetStatement.setOperatorsImpl.parent = newSetStatement
newSetStatement.Clauses = []jet.Clause{&newSetStatement.setOperator}
return newSetStatement
}
2019-08-17 10:43:16 +02:00
func (s *setStatementImpl) ORDER_BY(orderByClauses ...jet.OrderByClause) setStatement {
2019-08-11 12:13:59 +02:00
s.setOperator.OrderBy.List = orderByClauses
return s
}
2019-08-17 10:43:16 +02:00
func (s *setStatementImpl) LIMIT(limit int64) setStatement {
2019-08-11 12:13:59 +02:00
s.setOperator.Limit.Count = limit
return s
}
2019-08-17 10:43:16 +02:00
func (s *setStatementImpl) OFFSET(offset int64) setStatement {
2019-08-11 12:13:59 +02:00
s.setOperator.Offset.Count = offset
return s
}
func (s *setStatementImpl) AsTable(alias string) SelectTable {
return newSelectTable(s, alias)
}
const (
2019-08-17 10:43:16 +02:00
union = "UNION"
2019-08-11 12:13:59 +02:00
)
func toSelectList(lhs, rhs jet.StatementWithProjections, selects ...jet.StatementWithProjections) []jet.StatementWithProjections {
return append([]jet.StatementWithProjections{lhs, rhs}, selects...)
}