jet/sqlbuilder/expression.go

234 lines
5.5 KiB
Go
Raw Normal View History

package sqlbuilder
import (
"github.com/dropbox/godropbox/errors"
)
2019-06-04 12:10:23 +02:00
// An Expression
type Expression interface {
2019-05-07 19:06:21 +02:00
clause
projection
groupByClause
2019-06-04 12:10:23 +02:00
OrderByClause
IS_NULL() BoolExpression
IS_NOT_NULL() BoolExpression
2019-05-29 14:03:38 +02:00
2019-06-04 12:10:23 +02:00
IN(expressions ...Expression) BoolExpression
NOT_IN(expressions ...Expression) BoolExpression
2019-05-07 19:06:21 +02:00
AS(alias string) projection
2019-05-29 14:03:38 +02:00
2019-06-04 12:10:23 +02:00
ASC() OrderByClause
DESC() OrderByClause
2019-06-04 12:10:23 +02:00
CAST_TO(dbType string) Expression
CAST_TO_BOOL() BoolExpression
CAST_TO_INTEGER() IntegerExpression
CAST_TO_DOUBLE() FloatExpression
CAST_TO_TEXT() StringExpression
CAST_TO_DATE() DateExpression
CAST_TO_TIME() TimeExpression
CAST_TO_TIMEZ() TimezExpression
CAST_TO_TIMESTAMP() TimestampExpression
CAST_TO_TIMESTAMPZ() TimestampzExpression
}
2019-03-31 09:17:28 +02:00
type expressionInterfaceImpl struct {
2019-06-04 12:10:23 +02:00
parent Expression
}
func (e *expressionInterfaceImpl) IS_NULL() BoolExpression {
2019-05-29 14:03:38 +02:00
return newPostifxBoolExpression(e.parent, "IS NULL")
}
func (e *expressionInterfaceImpl) IS_NOT_NULL() BoolExpression {
2019-05-29 14:03:38 +02:00
return newPostifxBoolExpression(e.parent, "IS NOT NULL")
}
2019-06-04 12:10:23 +02:00
func (e *expressionInterfaceImpl) IN(expressions ...Expression) BoolExpression {
return newBinaryBoolExpression(e.parent, WRAP(expressions...), "IN")
}
2019-06-04 12:10:23 +02:00
func (e *expressionInterfaceImpl) NOT_IN(expressions ...Expression) BoolExpression {
return newBinaryBoolExpression(e.parent, WRAP(expressions...), "NOT IN")
}
2019-05-07 19:06:21 +02:00
func (e *expressionInterfaceImpl) AS(alias string) projection {
2019-03-31 09:17:28 +02:00
return NewAlias(e.parent, alias)
}
2019-06-04 12:10:23 +02:00
func (e *expressionInterfaceImpl) ASC() OrderByClause {
2019-05-07 19:06:21 +02:00
return &orderByClauseImpl{expression: e.parent, ascent: true}
}
2019-06-04 12:10:23 +02:00
func (e *expressionInterfaceImpl) DESC() OrderByClause {
2019-05-07 19:06:21 +02:00
return &orderByClauseImpl{expression: e.parent, ascent: false}
}
2019-06-04 12:10:23 +02:00
func (e *expressionInterfaceImpl) CAST_TO(dbType string) Expression {
2019-06-03 17:05:29 +02:00
return newCast(e.parent, dbType)
}
func (e *expressionInterfaceImpl) CAST_TO_BOOL() BoolExpression {
return newBoolCast(e.parent)
}
func (e *expressionInterfaceImpl) CAST_TO_INTEGER() IntegerExpression {
return newIntegerCast(e.parent)
}
func (e *expressionInterfaceImpl) CAST_TO_DOUBLE() FloatExpression {
return newDoubleCast(e.parent)
}
func (e *expressionInterfaceImpl) CAST_TO_TEXT() StringExpression {
return newTextCast(e.parent)
}
func (e *expressionInterfaceImpl) CAST_TO_DATE() DateExpression {
return newDateCast(e.parent)
}
func (e *expressionInterfaceImpl) CAST_TO_TIME() TimeExpression {
return newTimeCast(e.parent)
}
func (e *expressionInterfaceImpl) CAST_TO_TIMEZ() TimezExpression {
return newTimezCast(e.parent)
}
func (e *expressionInterfaceImpl) CAST_TO_TIMESTAMP() TimestampExpression {
return newTimestampCast(e.parent)
}
func (e *expressionInterfaceImpl) CAST_TO_TIMESTAMPZ() TimestampzExpression {
return newTimestampzCast(e.parent)
}
func (e *expressionInterfaceImpl) serializeForGroupBy(statement statementType, out *queryData) error {
return e.parent.serialize(statement, out, NO_WRAP)
2019-05-07 19:06:21 +02:00
}
func (e *expressionInterfaceImpl) serializeForProjection(statement statementType, out *queryData) error {
return e.parent.serialize(statement, out, NO_WRAP)
}
func (e *expressionInterfaceImpl) serializeAsOrderBy(statement statementType, out *queryData) error {
return e.parent.serialize(statement, out, NO_WRAP)
2019-05-08 12:49:36 +02:00
}
2019-03-31 09:17:28 +02:00
// Representation of binary operations (e.g. comparisons, arithmetic)
2019-05-29 14:03:38 +02:00
type binaryOpExpression struct {
2019-06-04 12:10:23 +02:00
lhs, rhs Expression
operator string
}
2019-06-04 12:10:23 +02:00
func newBinaryExpression(lhs, rhs Expression, operator string) binaryOpExpression {
2019-05-29 14:03:38 +02:00
binaryExpression := binaryOpExpression{
2019-03-31 09:17:28 +02:00
lhs: lhs,
rhs: rhs,
operator: operator,
}
2019-03-31 14:07:58 +02:00
return binaryExpression
}
func (c *binaryOpExpression) serialize(statement statementType, out *queryData, options ...serializeOption) error {
2019-05-13 12:33:11 +02:00
if c == nil {
2019-06-04 12:10:23 +02:00
return errors.New("Binary Expression is nil.")
2019-05-13 12:33:11 +02:00
}
if c.lhs == nil {
return errors.Newf("nil lhs.")
}
2019-05-01 17:25:10 +02:00
if c.rhs == nil {
return errors.Newf("nil rhs.")
}
wrap := !contains(options, NO_WRAP)
2019-05-01 17:25:10 +02:00
2019-05-01 18:23:19 +02:00
if wrap {
out.writeString("(")
2019-05-01 17:25:10 +02:00
}
if err := c.lhs.serialize(statement, out); err != nil {
return err
}
out.writeString(" " + c.operator + " ")
if err := c.rhs.serialize(statement, out); err != nil {
return err
}
2019-05-01 18:23:19 +02:00
if wrap {
out.writeString(")")
2019-05-01 17:25:10 +02:00
}
return nil
}
2019-06-04 12:10:23 +02:00
// A prefix operator Expression
2019-05-29 14:03:38 +02:00
type prefixOpExpression struct {
2019-06-04 12:10:23 +02:00
expression Expression
operator string
}
2019-06-04 12:10:23 +02:00
func newPrefixExpression(expression Expression, operator string) prefixOpExpression {
2019-05-29 14:03:38 +02:00
prefixExpression := prefixOpExpression{
2019-03-31 09:17:28 +02:00
expression: expression,
operator: operator,
}
2019-03-31 14:07:58 +02:00
return prefixExpression
}
func (p *prefixOpExpression) serialize(statement statementType, out *queryData, options ...serializeOption) error {
2019-05-13 12:33:11 +02:00
if p == nil {
2019-06-04 12:10:23 +02:00
return errors.New("Prefix Expression is nil.")
2019-05-13 12:33:11 +02:00
}
out.writeString(p.operator + " ")
2019-03-31 09:17:28 +02:00
if p.expression == nil {
2019-06-04 12:10:23 +02:00
return errors.Newf("nil prefix Expression.")
}
if err := p.expression.serialize(statement, out); err != nil {
return err
}
2019-03-31 09:17:28 +02:00
return nil
}
2019-05-29 14:03:38 +02:00
2019-06-04 12:10:23 +02:00
// A postifx operator Expression
2019-05-29 14:03:38 +02:00
type postfixOpExpression struct {
2019-06-04 12:10:23 +02:00
expression Expression
2019-05-29 14:03:38 +02:00
operator string
}
2019-06-04 12:10:23 +02:00
func newPostfixOpExpression(expression Expression, operator string) postfixOpExpression {
2019-05-29 14:03:38 +02:00
postfixOpExpression := postfixOpExpression{
expression: expression,
operator: operator,
}
return postfixOpExpression
}
func (p *postfixOpExpression) serialize(statement statementType, out *queryData, options ...serializeOption) error {
2019-05-29 14:03:38 +02:00
if p == nil {
2019-06-04 12:10:23 +02:00
return errors.New("Postifx operator Expression is nil.")
2019-05-29 14:03:38 +02:00
}
if p.expression == nil {
2019-06-04 12:10:23 +02:00
return errors.Newf("nil prefix Expression.")
2019-05-29 14:03:38 +02:00
}
if err := p.expression.serialize(statement, out); err != nil {
return err
}
out.writeString(p.operator)
return nil
}