Платформа ЦРНП "Мирокод" для разработки проектов
https://git.mirocod.ru
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
160 lines
3.3 KiB
160 lines
3.3 KiB
// Copyright 2016 The Xorm Authors. All rights reserved. |
|
// Use of this source code is governed by a BSD-style |
|
// license that can be found in the LICENSE file. |
|
|
|
package builder |
|
|
|
import "fmt" |
|
|
|
// WriteMap writes conditions' SQL to Writer, op could be =, <>, >, <, <=, >= and etc. |
|
func WriteMap(w Writer, data map[string]interface{}, op string) error { |
|
var args = make([]interface{}, 0, len(data)) |
|
var i = 0 |
|
keys := make([]string, 0, len(data)) |
|
for k := range data { |
|
keys = append(keys, k) |
|
} |
|
|
|
for _, k := range keys { |
|
v := data[k] |
|
switch v.(type) { |
|
case expr: |
|
if _, err := fmt.Fprintf(w, "%s%s(", k, op); err != nil { |
|
return err |
|
} |
|
|
|
if err := v.(expr).WriteTo(w); err != nil { |
|
return err |
|
} |
|
|
|
if _, err := fmt.Fprintf(w, ")"); err != nil { |
|
return err |
|
} |
|
case *Builder: |
|
if _, err := fmt.Fprintf(w, "%s%s(", k, op); err != nil { |
|
return err |
|
} |
|
|
|
if err := v.(*Builder).WriteTo(w); err != nil { |
|
return err |
|
} |
|
|
|
if _, err := fmt.Fprintf(w, ")"); err != nil { |
|
return err |
|
} |
|
default: |
|
if _, err := fmt.Fprintf(w, "%s%s?", k, op); err != nil { |
|
return err |
|
} |
|
args = append(args, v) |
|
} |
|
if i != len(data)-1 { |
|
if _, err := fmt.Fprint(w, " AND "); err != nil { |
|
return err |
|
} |
|
} |
|
i = i + 1 |
|
} |
|
w.Append(args...) |
|
return nil |
|
} |
|
|
|
// Lt defines < condition |
|
type Lt map[string]interface{} |
|
|
|
var _ Cond = Lt{} |
|
|
|
// WriteTo write SQL to Writer |
|
func (lt Lt) WriteTo(w Writer) error { |
|
return WriteMap(w, lt, "<") |
|
} |
|
|
|
// And implements And with other conditions |
|
func (lt Lt) And(conds ...Cond) Cond { |
|
return condAnd{lt, And(conds...)} |
|
} |
|
|
|
// Or implements Or with other conditions |
|
func (lt Lt) Or(conds ...Cond) Cond { |
|
return condOr{lt, Or(conds...)} |
|
} |
|
|
|
// IsValid tests if this Eq is valid |
|
func (lt Lt) IsValid() bool { |
|
return len(lt) > 0 |
|
} |
|
|
|
// Lte defines <= condition |
|
type Lte map[string]interface{} |
|
|
|
var _ Cond = Lte{} |
|
|
|
// WriteTo write SQL to Writer |
|
func (lte Lte) WriteTo(w Writer) error { |
|
return WriteMap(w, lte, "<=") |
|
} |
|
|
|
// And implements And with other conditions |
|
func (lte Lte) And(conds ...Cond) Cond { |
|
return And(lte, And(conds...)) |
|
} |
|
|
|
// Or implements Or with other conditions |
|
func (lte Lte) Or(conds ...Cond) Cond { |
|
return Or(lte, Or(conds...)) |
|
} |
|
|
|
// IsValid tests if this Eq is valid |
|
func (lte Lte) IsValid() bool { |
|
return len(lte) > 0 |
|
} |
|
|
|
// Gt defines > condition |
|
type Gt map[string]interface{} |
|
|
|
var _ Cond = Gt{} |
|
|
|
// WriteTo write SQL to Writer |
|
func (gt Gt) WriteTo(w Writer) error { |
|
return WriteMap(w, gt, ">") |
|
} |
|
|
|
// And implements And with other conditions |
|
func (gt Gt) And(conds ...Cond) Cond { |
|
return And(gt, And(conds...)) |
|
} |
|
|
|
// Or implements Or with other conditions |
|
func (gt Gt) Or(conds ...Cond) Cond { |
|
return Or(gt, Or(conds...)) |
|
} |
|
|
|
// IsValid tests if this Eq is valid |
|
func (gt Gt) IsValid() bool { |
|
return len(gt) > 0 |
|
} |
|
|
|
// Gte defines >= condition |
|
type Gte map[string]interface{} |
|
|
|
var _ Cond = Gte{} |
|
|
|
// WriteTo write SQL to Writer |
|
func (gte Gte) WriteTo(w Writer) error { |
|
return WriteMap(w, gte, ">=") |
|
} |
|
|
|
// And implements And with other conditions |
|
func (gte Gte) And(conds ...Cond) Cond { |
|
return And(gte, And(conds...)) |
|
} |
|
|
|
// Or implements Or with other conditions |
|
func (gte Gte) Or(conds ...Cond) Cond { |
|
return Or(gte, Or(conds...)) |
|
} |
|
|
|
// IsValid tests if this Eq is valid |
|
func (gte Gte) IsValid() bool { |
|
return len(gte) > 0 |
|
}
|
|
|