2019-08-03 14:10:47 +02:00
|
|
|
package postgres
|
|
|
|
|
|
|
|
|
|
import (
|
2019-08-06 10:29:04 +02:00
|
|
|
"errors"
|
2019-08-03 14:10:47 +02:00
|
|
|
"github.com/go-jet/jet/internal/jet"
|
|
|
|
|
"strconv"
|
2019-08-06 10:29:04 +02:00
|
|
|
"strings"
|
2019-08-03 14:10:47 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
var Dialect = NewDialect()
|
|
|
|
|
|
|
|
|
|
func NewDialect() jet.Dialect {
|
|
|
|
|
|
2019-08-06 10:29:04 +02:00
|
|
|
serializeOverrides := map[string]jet.SerializeOverride{}
|
|
|
|
|
serializeOverrides["REGEXP_LIKE"] = postgres_REGEXP_LIKE_function
|
|
|
|
|
|
2019-08-03 14:10:47 +02:00
|
|
|
dialectParams := jet.DialectParams{
|
|
|
|
|
Name: "PostgreSQL",
|
|
|
|
|
PackageName: "postgres",
|
|
|
|
|
CastOverride: castFunc,
|
2019-08-06 10:29:04 +02:00
|
|
|
SerializeOverrides: serializeOverrides,
|
2019-08-03 14:10:47 +02:00
|
|
|
AliasQuoteChar: '"',
|
|
|
|
|
IdentifierQuoteChar: '"',
|
|
|
|
|
ArgumentPlaceholder: func(ord int) string {
|
|
|
|
|
return "$" + strconv.Itoa(ord)
|
|
|
|
|
},
|
2019-08-06 10:29:04 +02:00
|
|
|
SetClause: postgresSetClause,
|
2019-08-03 14:10:47 +02:00
|
|
|
SupportsReturning: true,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return jet.NewDialect(dialectParams)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func castFunc(expression jet.Expression, castType string) jet.SerializeFunc {
|
|
|
|
|
return func(statement jet.StatementType, out *jet.SqlBuilder, options ...jet.SerializeOption) error {
|
|
|
|
|
if err := jet.Serialize(expression, statement, out, options...); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
out.WriteString("::" + castType)
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-06 10:29:04 +02:00
|
|
|
func postgresSetClause(columns []jet.IColumn, values []jet.Clause, out *jet.SqlBuilder) (err error) {
|
2019-08-03 14:10:47 +02:00
|
|
|
if len(columns) > 1 {
|
|
|
|
|
out.WriteString("(")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err = jet.SerializeColumnNames(columns, out)
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if len(columns) > 1 {
|
|
|
|
|
out.WriteString(")")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
out.WriteString("=")
|
|
|
|
|
|
|
|
|
|
if len(values) > 1 {
|
|
|
|
|
out.WriteString("(")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err = jet.SerializeClauseList(jet.UpdateStatementType, values, out)
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if len(values) > 1 {
|
|
|
|
|
out.WriteString(")")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return
|
|
|
|
|
}
|
2019-08-06 10:29:04 +02:00
|
|
|
|
|
|
|
|
func postgres_REGEXP_LIKE_function(expressions ...jet.Expression) jet.SerializeFunc {
|
|
|
|
|
return func(statement jet.StatementType, out *jet.SqlBuilder, options ...jet.SerializeOption) error {
|
|
|
|
|
if len(expressions) < 2 {
|
|
|
|
|
return errors.New("jet: invalid number of expressions for operator")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if err := jet.Serialize(expressions[0], statement, out, options...); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
caseSensitive := false
|
|
|
|
|
|
|
|
|
|
if len(expressions) >= 3 {
|
|
|
|
|
if stringLiteral, ok := expressions[2].(jet.LiteralExpression); ok {
|
|
|
|
|
matchType := stringLiteral.Value().(string)
|
|
|
|
|
|
|
|
|
|
caseSensitive = !strings.Contains(matchType, "i")
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if caseSensitive {
|
|
|
|
|
out.WriteString("~")
|
|
|
|
|
} else {
|
|
|
|
|
out.WriteString("~*")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if err := jet.Serialize(expressions[1], statement, out, options...); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
}
|