2019-03-30 10:05:30 +01:00
|
|
|
package sqlbuilder
|
|
|
|
|
|
2019-05-06 12:42:15 +02:00
|
|
|
import "errors"
|
|
|
|
|
|
2019-05-05 18:03:30 +02:00
|
|
|
type funcExpressionImpl struct {
|
2019-04-03 11:03:07 +02:00
|
|
|
expressionInterfaceImpl
|
|
|
|
|
|
2019-06-01 15:00:37 +02:00
|
|
|
name string
|
|
|
|
|
expressions []expression
|
2019-05-05 18:03:30 +02:00
|
|
|
}
|
|
|
|
|
|
2019-05-07 19:06:21 +02:00
|
|
|
func ROW(expressions ...expression) expression {
|
2019-05-05 18:03:30 +02:00
|
|
|
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 {
|
2019-05-05 18:03:30 +02:00
|
|
|
funcExp := &funcExpressionImpl{
|
2019-06-01 15:00:37 +02:00
|
|
|
name: name,
|
|
|
|
|
expressions: expressions,
|
2019-04-03 11:03:07 +02:00
|
|
|
}
|
2019-03-30 10:05:30 +01:00
|
|
|
|
2019-05-05 18:03:30 +02:00
|
|
|
if parent != nil {
|
|
|
|
|
funcExp.expressionInterfaceImpl.parent = parent
|
|
|
|
|
} else {
|
|
|
|
|
funcExp.expressionInterfaceImpl.parent = funcExp
|
|
|
|
|
}
|
2019-03-30 10:05:30 +01:00
|
|
|
|
2019-05-05 18:03:30 +02:00
|
|
|
return funcExp
|
2019-03-30 10:05:30 +01:00
|
|
|
}
|
|
|
|
|
|
2019-05-31 14:37:51 +02:00
|
|
|
func (f *funcExpressionImpl) serialize(statement statementType, out *queryData, options ...serializeOption) error {
|
2019-05-13 12:33:11 +02:00
|
|
|
if f == nil {
|
2019-06-01 15:00:37 +02:00
|
|
|
return errors.New("Function expressions is nil. ")
|
2019-05-13 12:33:11 +02:00
|
|
|
}
|
|
|
|
|
|
2019-05-12 18:15:23 +02:00
|
|
|
out.writeString(f.name + "(")
|
|
|
|
|
|
2019-06-01 15:00:37 +02:00
|
|
|
err := serializeExpressionList(statement, f.expressions, ", ", out)
|
2019-03-30 10:05:30 +01:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2019-05-08 13:47:01 +02:00
|
|
|
out.writeString(")")
|
2019-03-30 10:05:30 +01:00
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2019-05-31 12:59:57 +02:00
|
|
|
type floatFunc struct {
|
2019-05-05 18:03:30 +02:00
|
|
|
funcExpressionImpl
|
2019-05-31 12:59:57 +02:00
|
|
|
floatInterfaceImpl
|
2019-05-05 18:03:30 +02:00
|
|
|
}
|
|
|
|
|
|
2019-05-31 12:59:57 +02:00
|
|
|
func newFloatFunc(name string, expressions ...expression) FloatExpression {
|
|
|
|
|
floatFunc := &floatFunc{}
|
2019-05-05 18:03:30 +02:00
|
|
|
|
2019-05-31 12:59:57 +02:00
|
|
|
floatFunc.funcExpressionImpl = *newFunc(name, expressions, floatFunc)
|
|
|
|
|
floatFunc.floatInterfaceImpl.parent = floatFunc
|
2019-05-05 18:03:30 +02:00
|
|
|
|
2019-05-31 12:59:57 +02:00
|
|
|
return floatFunc
|
2019-05-20 17:37:55 +02:00
|
|
|
}
|
|
|
|
|
|
2019-05-31 12:59:57 +02:00
|
|
|
type integerFunc struct {
|
|
|
|
|
funcExpressionImpl
|
|
|
|
|
integerInterfaceImpl
|
2019-05-06 12:42:15 +02:00
|
|
|
}
|
|
|
|
|
|
2019-05-31 12:59:57 +02:00
|
|
|
func newIntegerFunc(name string, expressions ...expression) IntegerExpression {
|
|
|
|
|
floatFunc := &integerFunc{}
|
2019-05-06 12:42:15 +02:00
|
|
|
|
2019-05-31 12:59:57 +02:00
|
|
|
floatFunc.funcExpressionImpl = *newFunc(name, expressions, floatFunc)
|
|
|
|
|
floatFunc.integerInterfaceImpl.parent = floatFunc
|
2019-05-06 12:42:15 +02:00
|
|
|
|
2019-05-31 12:59:57 +02:00
|
|
|
return floatFunc
|
2019-05-06 12:42:15 +02:00
|
|
|
}
|
|
|
|
|
|
2019-06-01 15:00:37 +02:00
|
|
|
// ------------------ Mathematical functions ---------------//
|
|
|
|
|
|
|
|
|
|
func ABSf(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("ABS", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func ABSi(integerExpression IntegerExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("ABS", integerExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func SQRTf(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("SQRT", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func SQRTi(integerExpression IntegerExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("SQRT", integerExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func CBRTf(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("CBRT", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func CBRTi(integerExpression IntegerExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("CBRT", integerExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func CEIL(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("CEIL", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func FLOOR(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("FLOOR", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func ROUND(floatExpression FloatExpression, intExpression ...IntegerExpression) FloatExpression {
|
|
|
|
|
if len(intExpression) > 0 {
|
|
|
|
|
return newFloatFunc("ROUND", floatExpression, intExpression[0])
|
|
|
|
|
}
|
|
|
|
|
return newFloatFunc("ROUND", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func SIGN(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("SIGN", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TRUNC(floatExpression FloatExpression, intExpression ...IntegerExpression) FloatExpression {
|
|
|
|
|
if len(intExpression) > 0 {
|
|
|
|
|
return newFloatFunc("TRUNC", floatExpression, intExpression[0])
|
|
|
|
|
}
|
|
|
|
|
return newFloatFunc("TRUNC", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func LN(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("LN", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func LOG(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("LOG", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ----------------- Group function operators -------------------//
|
|
|
|
|
|
|
|
|
|
func MAXf(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("MAX", floatExpression)
|
2019-05-06 12:42:15 +02:00
|
|
|
}
|
|
|
|
|
|
2019-05-31 12:59:57 +02:00
|
|
|
func MAXi(integerExpression IntegerExpression) IntegerExpression {
|
|
|
|
|
return newIntegerFunc("MAX", integerExpression)
|
2019-05-06 12:42:15 +02:00
|
|
|
}
|
|
|
|
|
|
2019-06-01 15:00:37 +02:00
|
|
|
func SUMf(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("SUM", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
2019-05-31 12:59:57 +02:00
|
|
|
func SUMi(integerExpression IntegerExpression) IntegerExpression {
|
|
|
|
|
return newIntegerFunc("SUM", integerExpression)
|
2019-05-06 12:42:15 +02:00
|
|
|
}
|
2019-06-01 15:00:37 +02:00
|
|
|
|
|
|
|
|
func COUNTf(floatExpression FloatExpression) FloatExpression {
|
|
|
|
|
return newFloatFunc("COUNT", floatExpression)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func COUNTi(integerExpression IntegerExpression) IntegerExpression {
|
|
|
|
|
return newIntegerFunc("COUNT", integerExpression)
|
|
|
|
|
}
|