jet/sqlbuilder/func_expression.go

163 lines
3.1 KiB
Go
Raw Normal View History

2019-03-30 10:05:30 +01:00
package sqlbuilder
2019-05-06 12:42:15 +02:00
import "errors"
type funcExpressionImpl struct {
expressionInterfaceImpl
2019-03-30 10:05:30 +01:00
name string
2019-05-07 19:06:21 +02:00
expression []expression
}
2019-05-07 19:06:21 +02:00
func ROW(expressions ...expression) expression {
return newFunc("ROW", expressions, nil)
2019-03-30 10:05:30 +01:00
}
2019-05-07 19:06:21 +02:00
func newFunc(name string, expressions []expression, parent expression) *funcExpressionImpl {
funcExp := &funcExpressionImpl{
name: name,
expression: expressions,
}
2019-03-30 10:05:30 +01:00
if parent != nil {
funcExp.expressionInterfaceImpl.parent = parent
} else {
funcExp.expressionInterfaceImpl.parent = funcExp
}
2019-03-30 10:05:30 +01:00
return funcExp
2019-03-30 10:05:30 +01:00
}
2019-05-07 19:06:21 +02:00
func (f *funcExpressionImpl) serialize(out *queryData) error {
2019-03-30 10:05:30 +01:00
out.WriteString(f.name)
out.WriteString("(")
err := serializeExpressionList(f.expression, ", ", out)
2019-03-30 10:05:30 +01:00
if err != nil {
return err
}
out.WriteString(")")
return nil
}
type numericFunc struct {
funcExpressionImpl
numericInterfaceImpl
}
2019-05-07 19:06:21 +02:00
func NewNumericFunc(name string, expressions ...expression) numericExpression {
numericFunc := &numericFunc{}
numericFunc.funcExpressionImpl = *newFunc(name, expressions, numericFunc)
numericFunc.numericInterfaceImpl.parent = numericFunc
return numericFunc
}
2019-03-31 14:07:58 +02:00
//func (f *FuncExpression) SerializeSqlForColumnList(out *bytes.Buffer) error {
2019-05-07 19:06:21 +02:00
// return f.serialize(out)
2019-03-31 14:07:58 +02:00
//}
2019-03-30 10:05:30 +01:00
2019-05-07 19:06:21 +02:00
func MAX(expression numericExpression) numericExpression {
return NewNumericFunc("MAX", expression)
2019-03-30 10:05:30 +01:00
}
2019-05-07 19:06:21 +02:00
func SUM(expression numericExpression) numericExpression {
return NewNumericFunc("SUM", expression)
2019-03-30 10:05:30 +01:00
}
2019-05-06 12:42:15 +02:00
type caseInterface interface {
2019-05-07 19:06:21 +02:00
expression
2019-05-06 12:42:15 +02:00
2019-05-07 19:06:21 +02:00
WHEN(condition expression) caseInterface
THEN(then expression) caseInterface
ELSE(els expression) caseInterface
2019-05-06 12:42:15 +02:00
}
type caseExpression struct {
expressionInterfaceImpl
2019-05-07 19:06:21 +02:00
expression expression
when []expression
then []expression
els expression
2019-05-06 12:42:15 +02:00
}
2019-05-07 19:06:21 +02:00
func CASE(expression ...expression) caseInterface {
2019-05-06 12:42:15 +02:00
caseExp := &caseExpression{}
if len(expression) == 1 {
caseExp.expression = expression[0]
}
caseExp.expressionInterfaceImpl.parent = caseExp
return caseExp
}
2019-05-07 19:06:21 +02:00
func (c *caseExpression) WHEN(when expression) caseInterface {
2019-05-06 12:42:15 +02:00
c.when = append(c.when, when)
return c
}
2019-05-07 19:06:21 +02:00
func (c *caseExpression) THEN(then expression) caseInterface {
2019-05-06 12:42:15 +02:00
c.then = append(c.then, then)
return c
}
2019-05-07 19:06:21 +02:00
func (c *caseExpression) ELSE(els expression) caseInterface {
2019-05-06 12:42:15 +02:00
c.els = els
return c
}
2019-05-07 19:06:21 +02:00
func (c *caseExpression) serialize(out *queryData) error {
2019-05-06 12:42:15 +02:00
out.WriteString("(CASE")
if c.expression != nil {
out.WriteString(" ")
2019-05-07 19:06:21 +02:00
err := c.expression.serialize(out)
2019-05-06 12:42:15 +02:00
if err != nil {
return err
}
}
if len(c.when) == 0 || len(c.then) == 0 {
return errors.New("Invalid case statement. There should be at least one when/then expression pair. ")
}
if len(c.when) != len(c.then) {
return errors.New("When and then expression count mismatch. ")
}
for i, when := range c.when {
out.WriteString(" WHEN ")
2019-05-07 19:06:21 +02:00
err := when.serialize(out)
2019-05-06 12:42:15 +02:00
if err != nil {
return err
}
out.WriteString(" THEN ")
2019-05-07 19:06:21 +02:00
err = c.then[i].serialize(out)
2019-05-06 12:42:15 +02:00
if err != nil {
return err
}
}
if c.els != nil {
out.WriteString(" ELSE ")
2019-05-07 19:06:21 +02:00
err := c.els.serialize(out)
2019-05-06 12:42:15 +02:00
if err != nil {
return err
}
}
out.WriteString(" END)")
return nil
}