2019-08-03 14:10:47 +02:00
|
|
|
package mysql
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"github.com/go-jet/jet/internal/jet"
|
|
|
|
|
)
|
|
|
|
|
|
2019-08-17 10:43:16 +02:00
|
|
|
// Dialect is implementation of MySQL dialect for SQL Builder serialisation.
|
|
|
|
|
var Dialect = newDialect()
|
2019-08-03 14:10:47 +02:00
|
|
|
|
2019-08-17 10:43:16 +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{}
|
|
|
|
|
operatorSerializeOverrides[jet.StringRegexpLikeOperator] = mysql_REGEXP_LIKE_operator
|
|
|
|
|
operatorSerializeOverrides[jet.StringNotRegexpLikeOperator] = mysql_NOT_REGEXP_LIKE_operator
|
|
|
|
|
operatorSerializeOverrides["IS DISTINCT FROM"] = mysql_IS_DISTINCT_FROM
|
|
|
|
|
operatorSerializeOverrides["IS NOT DISTINCT FROM"] = mysql_IS_NOT_DISTINCT_FROM
|
|
|
|
|
operatorSerializeOverrides["/"] = mysql_DIVISION
|
|
|
|
|
operatorSerializeOverrides["#"] = mysql_BIT_XOR
|
|
|
|
|
operatorSerializeOverrides[jet.StringConcatOperator] = mysql_CONCAT_operator
|
2019-08-03 14:10:47 +02:00
|
|
|
|
|
|
|
|
mySQLDialectParams := jet.DialectParams{
|
2019-08-15 13:54:05 +02:00
|
|
|
Name: "MySQL",
|
|
|
|
|
PackageName: "mysql",
|
|
|
|
|
OperatorSerializeOverrides: operatorSerializeOverrides,
|
|
|
|
|
AliasQuoteChar: '"',
|
|
|
|
|
IdentifierQuoteChar: '`',
|
2019-08-03 14:10:47 +02:00
|
|
|
ArgumentPlaceholder: func(int) string {
|
|
|
|
|
return "?"
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return jet.NewDialect(mySQLDialectParams)
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-06 10:29:04 +02:00
|
|
|
func mysql_BIT_XOR(expressions ...jet.Expression) jet.SerializeFunc {
|
2019-08-13 13:57:26 +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 {
|
2019-08-13 13:57:26 +02:00
|
|
|
panic("jet: invalid number of expressions for operator XOR")
|
2019-08-06 10:29:04 +02:00
|
|
|
}
|
2019-08-03 14:10:47 +02:00
|
|
|
|
2019-08-06 10:29:04 +02:00
|
|
|
lhs := expressions[0]
|
|
|
|
|
rhs := expressions[1]
|
2019-08-03 14:10:47 +02:00
|
|
|
|
2019-08-13 13:57:26 +02:00
|
|
|
jet.Serialize(lhs, statement, out, options...)
|
2019-08-03 14:10:47 +02:00
|
|
|
|
2019-08-06 10:29:04 +02:00
|
|
|
out.WriteString("^")
|
2019-08-03 14:10:47 +02:00
|
|
|
|
2019-08-13 13:57:26 +02:00
|
|
|
jet.Serialize(rhs, statement, out, options...)
|
2019-08-03 14:10:47 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-06 10:29:04 +02:00
|
|
|
func mysql_CONCAT_operator(expressions ...jet.Expression) jet.SerializeFunc {
|
2019-08-13 13:57:26 +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 {
|
2019-08-13 13:57:26 +02:00
|
|
|
panic("jet: invalid number of expressions for operator CONCAT")
|
2019-08-03 14:10:47 +02:00
|
|
|
}
|
2019-08-06 10:29:04 +02:00
|
|
|
out.WriteString("CONCAT(")
|
2019-08-03 14:10:47 +02:00
|
|
|
|
2019-08-13 13:57:26 +02:00
|
|
|
jet.Serialize(expressions[0], statement, out, options...)
|
2019-08-03 14:10:47 +02:00
|
|
|
|
2019-08-06 10:29:04 +02:00
|
|
|
out.WriteString(", ")
|
2019-08-03 14:10:47 +02:00
|
|
|
|
2019-08-13 13:57:26 +02:00
|
|
|
jet.Serialize(expressions[1], statement, out, options...)
|
2019-08-06 10:29:04 +02:00
|
|
|
|
|
|
|
|
out.WriteString(")")
|
2019-08-03 14:10:47 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func mysql_DIVISION(expressions ...jet.Expression) jet.SerializeFunc {
|
2019-08-13 13:57:26 +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 {
|
2019-08-13 13:57:26 +02:00
|
|
|
panic("jet: invalid number of expressions for operator DIV")
|
2019-08-03 14:10:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
lhs := expressions[0]
|
|
|
|
|
rhs := expressions[1]
|
|
|
|
|
|
2019-08-13 13:57:26 +02:00
|
|
|
jet.Serialize(lhs, statement, out, options...)
|
2019-08-03 14:10:47 +02:00
|
|
|
|
|
|
|
|
_, isLhsInt := lhs.(IntegerExpression)
|
|
|
|
|
_, isRhsInt := rhs.(IntegerExpression)
|
|
|
|
|
|
|
|
|
|
if isLhsInt && isRhsInt {
|
|
|
|
|
out.WriteString("DIV")
|
|
|
|
|
} else {
|
|
|
|
|
out.WriteString("/")
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-13 13:57:26 +02:00
|
|
|
jet.Serialize(rhs, statement, out, options...)
|
2019-08-03 14:10:47 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func mysql_IS_NOT_DISTINCT_FROM(expressions ...jet.Expression) jet.SerializeFunc {
|
2019-08-13 13:57:26 +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 {
|
2019-08-13 13:57:26 +02:00
|
|
|
panic("jet: invalid number of expressions for operator")
|
2019-08-03 14:10:47 +02:00
|
|
|
}
|
|
|
|
|
|
2019-08-13 13:57:26 +02:00
|
|
|
jet.Serialize(expressions[0], statement, out)
|
2019-08-03 14:10:47 +02:00
|
|
|
out.WriteString("<=>")
|
2019-08-13 13:57:26 +02:00
|
|
|
jet.Serialize(expressions[1], statement, out)
|
2019-08-03 14:10:47 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func mysql_IS_DISTINCT_FROM(expressions ...jet.Expression) jet.SerializeFunc {
|
2019-08-13 13:57:26 +02:00
|
|
|
return func(statement jet.StatementType, out *jet.SqlBuilder, options ...jet.SerializeOption) {
|
2019-08-06 10:29:04 +02:00
|
|
|
out.WriteString("NOT(")
|
2019-08-13 13:57:26 +02:00
|
|
|
mysql_IS_NOT_DISTINCT_FROM(expressions...)(statement, out, options...)
|
2019-08-06 10:29:04 +02:00
|
|
|
out.WriteString(")")
|
2019-08-03 14:10:47 +02:00
|
|
|
}
|
|
|
|
|
}
|
2019-08-15 11:10:02 +02:00
|
|
|
|
|
|
|
|
func mysql_REGEXP_LIKE_operator(expressions ...jet.Expression) jet.SerializeFunc {
|
|
|
|
|
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)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
out.WriteString("REGEXP")
|
|
|
|
|
|
|
|
|
|
if caseSensitive {
|
|
|
|
|
out.WriteString("BINARY")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
jet.Serialize(expressions[1], statement, out, options...)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func mysql_NOT_REGEXP_LIKE_operator(expressions ...jet.Expression) jet.SerializeFunc {
|
|
|
|
|
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)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
out.WriteString("NOT REGEXP")
|
|
|
|
|
|
|
|
|
|
if caseSensitive {
|
|
|
|
|
out.WriteString("BINARY")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
jet.Serialize(expressions[1], statement, out, options...)
|
|
|
|
|
}
|
|
|
|
|
}
|