-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwhere.go
86 lines (76 loc) · 1.89 KB
/
where.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
// Copyright (c) 2023 William Dode
// Licensed under the MIT license. See LICENSE file in the project root for details.
package sqlo
import (
"fmt"
"strings"
)
type Where struct {
Style string // $ ? @p
where []string
Args []interface{}
}
// remplace %s par ? ou $d
func (w *Where) Appendf(s string, a ...interface{}) {
if len(s) > 0 {
arg_nb := []interface{}{} // deviendra $1 $2 $...
for i := 0; i < len(a); i++ {
switch w.Style {
case "?":
arg_nb = append(arg_nb, "?")
case "@p":
arg_nb = append(arg_nb, fmt.Sprintf("@p%d", len(w.Args)+1+i))
case "", "$":
arg_nb = append(arg_nb, fmt.Sprintf("$%d", len(w.Args)+1+i))
}
}
w.where = append(w.where, fmt.Sprintf(s, arg_nb...))
}
if len(a) > 0 {
w.Args = append(w.Args, a...)
}
}
// ajout sous forme de liste
// exemple AppendListf("xyz in (%s)", "a","b","c")
// doit ajouter "xyz in ($1,$2,$3)" avec args "a","b","c"
func (w *Where) AppendListf(s string, a ...interface{}) {
q := []string{} // les $1 $2...
for i := 0; i < len(a); i++ {
w.Args = append(w.Args, a[i])
switch w.Style {
case "?":
q = append(q, "?")
case "@p":
q = append(q, fmt.Sprintf("@p%d", len(w.Args)))
case "", "$":
q = append(q, fmt.Sprintf("$%d", len(w.Args)))
}
}
w.where = append(w.where, fmt.Sprintf(s, strings.Join(q, ",")))
}
// renvoi suite avec and, sans le premier and
func (w *Where) And() string {
return strings.Join(w.where, " and ")
}
// renvoi suite de and avec le premier and si non vide
func (w *Where) AndAnd() string {
if len(w.where) == 0 {
return ""
}
return " and " + w.And()
}
// renvoi le where avec "where" sauf si vide
func (w *Where) Where() string {
if len(w.where) == 0 {
return ""
}
ands := w.And()
return " where " + ands
}
// renvoi une copie
func (w *Where) Clone() *Where {
wc := &Where{}
wc.Args = append(wc.Args, w.Args...)
wc.where = append(wc.where, w.where...)
return wc
}