jet/sqlbuilder/func.go

55 lines
987 B
Go
Raw Normal View History

2019-03-30 10:05:30 +01:00
package sqlbuilder
import "bytes"
type FuncExpression struct {
name string
expression Expression
alias string
}
2019-03-31 14:07:58 +02:00
func (f *FuncExpression) As(alias string) Clause {
2019-03-30 10:05:30 +01:00
newFuncExpression := *f
newFuncExpression.alias = alias
return &newFuncExpression
}
2019-03-31 14:07:58 +02:00
func (f *FuncExpression) SerializeSql(out *bytes.Buffer, options ...serializeOption) error {
2019-03-30 10:05:30 +01:00
out.WriteString(f.name)
out.WriteString("(")
err := f.expression.SerializeSql(out)
if err != nil {
return err
}
out.WriteString(")")
if f.alias != "" {
out.WriteString(` AS "`)
out.WriteString(f.alias)
out.WriteString(`"`)
}
return nil
}
2019-03-31 14:07:58 +02:00
//func (f *FuncExpression) SerializeSqlForColumnList(out *bytes.Buffer) error {
// return f.SerializeSql(out)
//}
2019-03-30 10:05:30 +01:00
func MAX(expression Expression) *FuncExpression {
return &FuncExpression{
name: "MAX",
expression: expression,
}
}
func SUM(expression Expression) *FuncExpression {
return &FuncExpression{
name: "SUM",
expression: expression,
}
}