217 lines
4.1 KiB
Go
217 lines
4.1 KiB
Go
package postgres
|
|
|
|
import (
|
|
"fmt"
|
|
"strconv"
|
|
|
|
"github.com/go-jet/jet/v2/internal/jet"
|
|
)
|
|
|
|
// Dialect is implementation of postgres dialect for SQL Builder serialisation.
|
|
var Dialect = newDialect()
|
|
|
|
func newDialect() jet.Dialect {
|
|
|
|
operatorSerializeOverrides := map[string]jet.SerializeOverride{}
|
|
operatorSerializeOverrides[jet.StringRegexpLikeOperator] = postgresREGEXPLIKEoperator
|
|
operatorSerializeOverrides[jet.StringNotRegexpLikeOperator] = postgresNOTREGEXPLIKEoperator
|
|
operatorSerializeOverrides["CAST"] = postgresCAST
|
|
|
|
dialectParams := jet.DialectParams{
|
|
Name: "PostgreSQL",
|
|
PackageName: "postgres",
|
|
OperatorSerializeOverrides: operatorSerializeOverrides,
|
|
AliasQuoteChar: '"',
|
|
IdentifierQuoteChar: '"',
|
|
ArgumentPlaceholder: func(ord int) string {
|
|
return "$" + strconv.Itoa(ord)
|
|
},
|
|
ReservedWords: reservedWords,
|
|
ValuesDefaultColumnName: func(index int) string {
|
|
return fmt.Sprintf("column%d", index+1)
|
|
},
|
|
}
|
|
|
|
return jet.NewDialect(dialectParams)
|
|
}
|
|
|
|
func postgresCAST(expressions ...jet.Serializer) jet.SerializerFunc {
|
|
return func(statement jet.StatementType, out *jet.SQLBuilder, options ...jet.SerializeOption) {
|
|
if len(expressions) < 2 {
|
|
panic("jet: invalid number of expressions for operator")
|
|
}
|
|
|
|
expression := expressions[0]
|
|
|
|
litExpr, ok := expressions[1].(jet.LiteralExpression)
|
|
|
|
if !ok {
|
|
panic("jet: cast invalid cast type")
|
|
}
|
|
|
|
castType, ok := litExpr.Value().(string)
|
|
|
|
if !ok {
|
|
panic("jet: cast type is not string")
|
|
}
|
|
|
|
jet.Serialize(expression, statement, out, options...)
|
|
out.WriteString("::" + castType)
|
|
}
|
|
}
|
|
|
|
func postgresREGEXPLIKEoperator(expressions ...jet.Serializer) jet.SerializerFunc {
|
|
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 {
|
|
caseSensitive = stringLiteral.Value().(bool)
|
|
}
|
|
}
|
|
|
|
if caseSensitive {
|
|
out.WriteString("~")
|
|
} else {
|
|
out.WriteString("~*")
|
|
}
|
|
|
|
jet.Serialize(expressions[1], statement, out, options...)
|
|
}
|
|
}
|
|
|
|
func postgresNOTREGEXPLIKEoperator(expressions ...jet.Serializer) jet.SerializerFunc {
|
|
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 {
|
|
caseSensitive = stringLiteral.Value().(bool)
|
|
}
|
|
}
|
|
|
|
if caseSensitive {
|
|
out.WriteString("!~")
|
|
} else {
|
|
out.WriteString("!~*")
|
|
}
|
|
|
|
jet.Serialize(expressions[1], statement, out, options...)
|
|
}
|
|
}
|
|
|
|
var reservedWords = []string{
|
|
"ALL",
|
|
"ANALYSE",
|
|
"ANALYZE",
|
|
"AND",
|
|
"ANY",
|
|
"ARRAY",
|
|
"AS",
|
|
"ASC",
|
|
"ASYMMETRIC",
|
|
"AUTHORIZATION",
|
|
"BINARY",
|
|
"BOTH",
|
|
"CASE",
|
|
"CAST",
|
|
"CHECK",
|
|
"COLLATE",
|
|
"COLLATION",
|
|
"COLUMN",
|
|
"CONCURRENTLY",
|
|
"CONSTRAINT",
|
|
"CREATE",
|
|
"CROSS",
|
|
"CURRENT_CATALOG",
|
|
"CURRENT_DATE",
|
|
"CURRENT_ROLE",
|
|
"CURRENT_SCHEMA",
|
|
"CURRENT_TIME",
|
|
"CURRENT_TIMESTAMP",
|
|
"CURRENT_USER",
|
|
"DEFAULT",
|
|
"DEFERRABLE",
|
|
"DESC",
|
|
"DISTINCT",
|
|
"DO",
|
|
"ELSE",
|
|
"END",
|
|
"EXCEPT",
|
|
"FALSE",
|
|
"FETCH",
|
|
"FOR",
|
|
"FOREIGN",
|
|
"FREEZE",
|
|
"FROM",
|
|
"FULL",
|
|
"GRANT",
|
|
"GROUP",
|
|
"HAVING",
|
|
"ILIKE",
|
|
"IN",
|
|
"INITIALLY",
|
|
"INNER",
|
|
"INTERSECT",
|
|
"INTO",
|
|
"IS",
|
|
"ISNULL",
|
|
"JOIN",
|
|
"LATERAL",
|
|
"LEADING",
|
|
"LEFT",
|
|
"LIKE",
|
|
"LIMIT",
|
|
"LOCALTIME",
|
|
"LOCALTIMESTAMP",
|
|
"NATURAL",
|
|
"NOT",
|
|
"NOTNULL",
|
|
"NULL",
|
|
"OFFSET",
|
|
"ON",
|
|
"ONLY",
|
|
"OR",
|
|
"ORDER",
|
|
"OUTER",
|
|
"OVERLAPS",
|
|
"PLACING",
|
|
"PRIMARY",
|
|
"REFERENCES",
|
|
"RETURNING",
|
|
"RIGHT",
|
|
"SELECT",
|
|
"SESSION_USER",
|
|
"SIMILAR",
|
|
"SOME",
|
|
"SYMMETRIC",
|
|
"SYSTEM_USER",
|
|
"TABLE",
|
|
"TABLESAMPLE",
|
|
"THEN",
|
|
"TO",
|
|
"TRAILING",
|
|
"TRUE",
|
|
"UNION",
|
|
"UNIQUE",
|
|
"USER",
|
|
"USING",
|
|
"VARIADIC",
|
|
"VERBOSE",
|
|
"WHEN",
|
|
"WHERE",
|
|
"WINDOW",
|
|
"WITH",
|
|
}
|