From 50a0a1a85c096715e8118ca313f210f80ddd0c79 Mon Sep 17 00:00:00 2001 From: what Date: Wed, 8 May 2024 22:58:27 +0800 Subject: [PATCH] =?UTF-8?q?[feat]=20=E8=B0=83=E6=95=B4=20=E6=8E=A5?= =?UTF-8?q?=E5=8F=A3=E6=96=87=E4=BB=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- condition.go | 21 ++++++++++------ condition_expr.go | 56 ++++++++++++++++++++++++++++++------------ contracts/contracts.go | 29 ---------------------- engine/engine_test.go | 15 ++++++----- helper.go | 4 +-- 5 files changed, 62 insertions(+), 63 deletions(-) diff --git a/condition.go b/condition.go index 42ab92b..1bae079 100644 --- a/condition.go +++ b/condition.go @@ -10,6 +10,11 @@ import ( "github.com/samber/lo" ) +const ( + OR contracts.ConditionType = "OR" + AND = "AND" +) + type Condition struct { parent contracts.Condition typ contracts.ConditionType // 分组类型 @@ -50,19 +55,19 @@ func (this Condition) IsAlwaysRight() bool { flag := []bool{} for _, expr := range this.exprs { - if expr.GetOperator() != contracts.EQ { + if expr.GetOperator() != EQ { flag = append(flag, false) continue } - if expr.GetTokenType() != contracts.SQL { + if expr.GetTokenType() != SQL { flag = append(flag, false) continue } eRight := fmt.Sprintf("%s.%s", expr.GetFieldResource(), expr.GetField()) == strings.ReplaceAll(expr.GetTokenName(), "`", "") - if this.typ == contracts.OR && eRight { + if this.typ == OR && eRight { return true } @@ -72,7 +77,7 @@ func (this Condition) IsAlwaysRight() bool { for _, cond := range this.childrens { cRight := cond.IsAlwaysRight() - if this.typ == contracts.OR && cRight { + if this.typ == OR && cRight { return true } @@ -106,16 +111,16 @@ func (this Condition) ToSql(m contracts.ConditionTokenValue) db.Expression { sql := strings.Join(conditions, " "+string(this.Type())+" ") if sql == "" { - if this.parent == nil && this.Type() == contracts.OR { + if this.parent == nil && this.Type() == OR { return db.Raw("false") - } else if this.parent == nil && this.Type() == contracts.AND { + } else if this.parent == nil && this.Type() == AND { return db.Raw("true") } return db.Raw("") } // 包裹 SQL, 避免语法表达错误 - if this.parent == nil || this.Type() == contracts.OR { + if this.parent == nil || this.Type() == OR { sql = "(" + sql + ")" } @@ -158,7 +163,7 @@ func (this Condition) GetFieldsValue(m contracts.ConditionTokenValue, isWithReso // 表达式 for _, item := range this.exprs { - if item.GetOperator() != contracts.EQ { + if item.GetOperator() != EQ { continue } diff --git a/condition_expr.go b/condition_expr.go index d67ffdf..f7c850b 100644 --- a/condition_expr.go +++ b/condition_expr.go @@ -12,6 +12,30 @@ import ( "github.com/spf13/cast" ) +const ( + SQL contracts.ConditionTokenType = "sql" + FUNC = "func" + PARAM = "param" + STRING = "string" +) + +const ( + IS_NULL contracts.ConditionOperator = "IS NULL" + IS_NOT_NULL = "IS NOT NULL" + EQ = "=" + NE = "!=" + GT = ">" + GE = ">=" + LT = "<" + LE = "<=" + LIKE = "LIKE" + NOT_LIKE = "NOT LIKE" + IN = "IN" + NOT_IN = "NOT IN" + REGEXP = "REGEXP" + NOT_REGEXP = "NOT REGEXP" +) + type ConditionExpr struct { parent contracts.Condition operator contracts.ConditionOperator @@ -65,24 +89,24 @@ func (this ConditionExpr) ToSql(m contracts.ConditionTokenValue) db.Expression { // secondary := "" switch operator { - case contracts.IS_NULL: - case contracts.IS_NOT_NULL: + case IS_NULL: + case IS_NOT_NULL: secondary = "" - case contracts.EQ, contracts.NE, - contracts.GT, contracts.GE, - contracts.LT, contracts.LE, - contracts.REGEXP, contracts.NOT_REGEXP: + case EQ, NE, + GT, GE, + LT, LE, + REGEXP, NOT_REGEXP: - if this.GetTokenType() == contracts.SQL { + if this.GetTokenType() == SQL { secondary = value } else { secondary = "'" + strings.Trim(value, "'") + "'" } - case contracts.LIKE, contracts.NOT_LIKE: + case LIKE, NOT_LIKE: secondary = "'%" + strings.Trim(value, "'") + "%'" - case contracts.IN, contracts.NOT_IN: + case IN, NOT_IN: secondary = "(" + lo.Ternary(value == "", "''", value) + ")" } @@ -118,7 +142,7 @@ func (this ConditionExpr) GetTokenType() contracts.ConditionTokenType { } func (this *ConditionExpr) GetTokenSqlValue(m contracts.ConditionTokenValue) string { - if this.GetTokenType() == contracts.SQL { + if this.GetTokenType() == SQL { return this.token } @@ -141,8 +165,8 @@ func (this *ConditionExpr) GetTokenSqlValue(m contracts.ConditionTokenValue) str } // 强制使用 in - if this.operator == contracts.EQ { - this.operator = contracts.IN + if this.operator == EQ { + this.operator = IN } return strings.Join(aStr, ", ") @@ -156,14 +180,14 @@ func (this *ConditionExpr) GetTokenSqlValue(m contracts.ConditionTokenValue) str func (this ConditionExpr) GetTokenValue(m contracts.ConditionTokenValue) any { switch this.GetTokenType() { - case contracts.PARAM: + case PARAM: if this.matchPrefix != "" { return m.GetParam(fmt.Sprintf("%s.%s", this.matchPrefix, this.token)).Value() } return m.GetParam(this.token).Value() - case contracts.STRING: + case STRING: return this.token - case contracts.FUNC: + case FUNC: switch this.token { case "UserID": return m.GetGlobalParamsUser().ID() @@ -187,7 +211,7 @@ func (this ConditionExpr) IsIgnoreEmptyParma(m contracts.ConditionTokenValue) bo return false } - if this.tokenType != contracts.PARAM { + if this.tokenType != PARAM { return false } diff --git a/contracts/contracts.go b/contracts/contracts.go index 75ad2e7..98c6890 100644 --- a/contracts/contracts.go +++ b/contracts/contracts.go @@ -9,35 +9,6 @@ type ConditionType string type ConditionOperator string type ConditionTokenType string -const ( - OR ConditionType = "OR" - AND ConditionType = "AND" -) - -const ( - SQL ConditionTokenType = "sql" - FUNC ConditionTokenType = "func" - PARAM ConditionTokenType = "param" - STRING ConditionTokenType = "string" -) - -const ( - IS_NULL ConditionOperator = "IS NULL" - IS_NOT_NULL ConditionOperator = "IS NOT NULL" - EQ ConditionOperator = "=" - NE ConditionOperator = "!=" - GT ConditionOperator = ">" - GE ConditionOperator = ">=" - LT ConditionOperator = "<" - LE ConditionOperator = "<=" - LIKE ConditionOperator = "LIKE" - NOT_LIKE ConditionOperator = "NOT LIKE" - IN ConditionOperator = "IN" - NOT_IN ConditionOperator = "NOT IN" - REGEXP ConditionOperator = "REGEXP" - NOT_REGEXP ConditionOperator = "NOT REGEXP" -) - type Condition interface { Type() ConditionType IsEmpty() bool diff --git a/engine/engine_test.go b/engine/engine_test.go index 33d118f..7d0a943 100644 --- a/engine/engine_test.go +++ b/engine/engine_test.go @@ -4,7 +4,6 @@ import ( "testing" "git.fsdpf.net/go/condition" - "git.fsdpf.net/go/condition/contracts" "git.fsdpf.net/go/req" ) @@ -24,11 +23,11 @@ func TestEngine(t *testing.T) { g: req.NewGlobalParam(`{"age": 30}`, nil), } - cond1 := condition.New(contracts.AND, "条件1") + cond1 := condition.New(condition.AND, "条件1") cond1.SetExpr(condition.NewExpr( "TestTable", "age", "age", - contracts.EQ, contracts.PARAM, + condition.EQ, condition.PARAM, false, "", "", )) @@ -67,10 +66,10 @@ func TestRelationEngine(t *testing.T) { }, } - cond1 := condition.New(contracts.AND, "条件1"). + cond1 := condition.New(condition.AND, "条件1"). SetExpr(condition.NewExpr( "TestTable", "age", "age", - contracts.EQ, contracts.PARAM, + condition.EQ, condition.PARAM, false, "", "", )) @@ -79,15 +78,15 @@ func TestRelationEngine(t *testing.T) { return nil }) - cond2 := condition.New(contracts.OR, "条件2"). + cond2 := condition.New(condition.OR, "条件2"). SetExpr(condition.NewExpr( "TestTableA", "age", "age", - contracts.EQ, contracts.PARAM, + condition.EQ, condition.PARAM, false, "", "", )). SetExpr(condition.NewExpr( "TestTable", "age", "age", - contracts.EQ, contracts.PARAM, + condition.EQ, condition.PARAM, false, "", "", )) diff --git a/helper.go b/helper.go index b245349..4b1f5c2 100644 --- a/helper.go +++ b/helper.go @@ -12,9 +12,9 @@ func NewConditionByRes(items []base.ResCondition, describe string) (root contrac for _, item := range items { switch item.Type { case "and": - conditions[item.Id] = &Condition{typ: contracts.AND} + conditions[item.Id] = &Condition{typ: AND} case "or": - conditions[item.Id] = &Condition{typ: contracts.OR} + conditions[item.Id] = &Condition{typ: OR} case "expr": conditions[item.Id] = &ConditionExpr{ field: item.Column,