-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathquery.go
More file actions
129 lines (110 loc) · 3.34 KB
/
query.go
File metadata and controls
129 lines (110 loc) · 3.34 KB
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
package flexpg
import (
"database/sql"
"strings"
"git.eaciitapp.com/sebar/dbflex"
"git.eaciitapp.com/sebar/dbflex/drivers/rdbms"
"github.com/eaciit/toolkit"
)
// Query implementaion of dbflex.IQuery
type Query struct {
rdbms.Query
db *sql.DB
sqlcommand string
}
// Cursor produces a cursor from query
func (q *Query) Cursor(in toolkit.M) dbflex.ICursor {
cursor := new(Cursor)
cursor.SetThis(cursor)
ct := q.Config(dbflex.ConfigKeyCommandType, dbflex.QuerySelect).(string)
if ct != dbflex.QuerySelect && ct != dbflex.QuerySQL {
cursor.SetError(toolkit.Errorf("cursor is used for only select command"))
return cursor
}
cmdtxt := q.Config(dbflex.ConfigKeyCommand, "").(string)
if cmdtxt == "" {
cursor.SetError(toolkit.Errorf("no command"))
return cursor
}
tablename := q.Config(dbflex.ConfigKeyTableName, "").(string)
cq := dbflex.From(tablename).Select("count(*) as Count")
if filter := q.Config(dbflex.ConfigKeyFilter, nil); filter != nil {
cq.Where(filter.(*dbflex.Filter))
}
cursor.SetCountCommand(cq)
rows, err := q.db.Query(cmdtxt)
if rows == nil {
cursor.SetError(toolkit.Errorf("%s. SQL Command: %s", err.Error(), cmdtxt))
} else {
cursor.SetFetcher(rows)
}
return cursor
}
// Execute will executes non-select command of a query
func (q *Query) Execute(in toolkit.M) (interface{}, error) {
cmdtype, ok := q.Config(dbflex.ConfigKeyCommandType, dbflex.QuerySelect).(string)
if !ok {
return nil, toolkit.Errorf("Operation is unknown. current operation is %s", cmdtype)
}
cmdtxt := q.Config(dbflex.ConfigKeyCommand, "").(string)
if cmdtxt == "" {
return nil, toolkit.Errorf("No command")
}
var (
sqlfieldnames []string
sqlvalues []string
)
data, hasData := in["data"]
if !hasData && !(cmdtype == dbflex.QueryDelete || cmdtype == dbflex.QuerySelect) {
return nil, toolkit.Error("non select and delete command should has data")
}
if hasData {
sqlfieldnames, _, _, sqlvalues = rdbms.ParseSQLMetadata(q, data)
affectedfields := q.Config("fields", []string{}).([]string)
if len(affectedfields) > 0 {
newfieldnames := []string{}
newvalues := []string{}
for idx, field := range sqlfieldnames {
for _, find := range affectedfields {
if strings.ToLower(field) == strings.ToLower(find) {
newfieldnames = append(newfieldnames, find)
newvalues = append(newvalues, sqlvalues[idx])
}
}
}
sqlfieldnames = newfieldnames
sqlvalues = newvalues
}
}
switch cmdtype {
case dbflex.QueryInsert:
cmdtxt = strings.Replace(cmdtxt, "{{.FIELDS}}", strings.Join(sqlfieldnames, ","), -1)
cmdtxt = strings.Replace(cmdtxt, "{{.VALUES}}", strings.Join(sqlvalues, ","), -1)
//toolkit.Printfn("\nCmd: %s", cmdtxt)
case dbflex.QueryUpdate:
//fmt.Println("fieldnames:", sqlfieldnames)
updatedfields := []string{}
for idx, fieldname := range sqlfieldnames {
updatedfields = append(updatedfields, fieldname+"="+sqlvalues[idx])
}
cmdtxt = strings.Replace(cmdtxt, "{{.FIELDVALUES}}", strings.Join(updatedfields, ","), -1)
}
//fmt.Println("Cmd: ", cmdtxt)
r, err := q.db.Exec(cmdtxt)
if err != nil {
return nil, toolkit.Errorf("%s. SQL Command: %s", err.Error(), cmdtxt)
}
return r, nil
}
// ExecType to identify type of exec
type ExecType int
const (
ExecQuery ExecType = iota
ExecNonQuery
ExecQueryRow
)
/*
func (q *Query) SQL(string cmd, exec) dbflex.IQuery {
swicth()
}
*/