jet/postgres/dialect.go

108 lines
2.8 KiB
Go
Raw Normal View History

2019-08-03 14:10:47 +02:00
package postgres
import (
"github.com/go-jet/jet/internal/jet"
"strconv"
)
2019-08-17 14:49:35 +02:00
// Dialect is implementation of postgres dialect for SQL Builder serialisation.
var Dialect = newDialect()
2019-08-03 14:10:47 +02:00
2019-08-17 14:49:35 +02:00
func newDialect() jet.Dialect {
2019-08-03 14:10:47 +02:00
2019-08-15 13:54:05 +02:00
operatorSerializeOverrides := map[string]jet.SerializeOverride{}
2019-09-20 19:54:56 +02:00
operatorSerializeOverrides[jet.StringRegexpLikeOperator] = postgresREGEXPLIKEoperator
operatorSerializeOverrides[jet.StringNotRegexpLikeOperator] = postgresNOTREGEXPLIKEoperator
2019-08-15 13:54:05 +02:00
operatorSerializeOverrides["CAST"] = postgresCAST
2019-08-03 14:10:47 +02:00
dialectParams := jet.DialectParams{
2019-08-15 13:54:05 +02:00
Name: "PostgreSQL",
PackageName: "postgres",
OperatorSerializeOverrides: operatorSerializeOverrides,
AliasQuoteChar: '"',
IdentifierQuoteChar: '"',
2019-08-03 14:10:47 +02:00
ArgumentPlaceholder: func(ord int) string {
return "$" + strconv.Itoa(ord)
},
}
return jet.NewDialect(dialectParams)
}
2019-08-06 12:12:48 +02:00
func postgresCAST(expressions ...jet.Expression) jet.SerializeFunc {
2019-08-17 18:32:01 +02:00
return func(statement jet.StatementType, out *jet.SQLBuilder, options ...jet.SerializeOption) {
2019-08-06 12:12:48 +02:00
if len(expressions) < 2 {
panic("jet: invalid number of expressions for operator")
2019-08-06 12:12:48 +02:00
}
expression := expressions[0]
litExpr, ok := expressions[1].(jet.LiteralExpression)
if !ok {
panic("jet: cast invalid cast type")
2019-08-06 12:12:48 +02:00
}
castType, ok := litExpr.Value().(string)
if !ok {
panic("jet: cast type is not string")
2019-08-06 12:12:48 +02:00
}
jet.Serialize(expression, statement, out, options...)
2019-08-03 14:10:47 +02:00
out.WriteString("::" + castType)
}
}
2019-09-20 19:54:56 +02:00
func postgresREGEXPLIKEoperator(expressions ...jet.Expression) jet.SerializeFunc {
2019-08-17 18:32:01 +02:00
return func(statement jet.StatementType, out *jet.SQLBuilder, options ...jet.SerializeOption) {
if len(expressions) < 2 {
panic("jet: invalid number of expressions for operator")
}
jet.Serialize(expressions[0], statement, out, options...)
caseSensitive := false
if len(expressions) >= 3 {
if stringLiteral, ok := expressions[2].(jet.LiteralExpression); ok {
2019-08-15 11:10:02 +02:00
caseSensitive = stringLiteral.Value().(bool)
}
}
if caseSensitive {
out.WriteString("~")
} else {
out.WriteString("~*")
}
jet.Serialize(expressions[1], statement, out, options...)
}
}
2019-08-15 11:10:02 +02:00
2019-09-20 19:54:56 +02:00
func postgresNOTREGEXPLIKEoperator(expressions ...jet.Expression) jet.SerializeFunc {
2019-08-17 18:32:01 +02:00
return func(statement jet.StatementType, out *jet.SQLBuilder, options ...jet.SerializeOption) {
2019-08-15 11:10:02 +02:00
if len(expressions) < 2 {
panic("jet: invalid number of expressions for operator")
}
jet.Serialize(expressions[0], statement, out, options...)
caseSensitive := false
if len(expressions) >= 3 {
if stringLiteral, ok := expressions[2].(jet.LiteralExpression); ok {
caseSensitive = stringLiteral.Value().(bool)
}
}
if caseSensitive {
out.WriteString("!~")
} else {
out.WriteString("!~*")
}
jet.Serialize(expressions[1], statement, out, options...)
}
}