/
query.go
81 lines (64 loc) · 1.87 KB
/
query.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
/*
Copyright 2020 Pressinfra SRL
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package mysql
import (
"strings"
)
// Query contains a escaped query string with variables marked with a question mark (?) and a slice
// of positional arguments
type Query struct {
escapedQuery string
args []interface{}
}
// String representation of the query
func (q *Query) String() string {
return q.escapedQuery
}
// Args is used in test
func (q *Query) Args() []interface{} {
return q.args
}
// NewQuery returns a new Query object
func NewQuery(q string, args ...interface{}) Query {
if q == "" {
panic("unexpected empty query")
}
if !strings.HasSuffix(q, ";") {
q += ";"
}
return Query{
escapedQuery: q,
args: args,
}
}
// ConcatenateQueries concatenates the provided queries into a single query
func ConcatenateQueries(queries ...Query) Query {
args := []interface{}{}
query := ""
for _, pq := range queries {
if query != "" {
if !strings.HasSuffix(query, "\n") {
query += "\n"
}
}
query += pq.escapedQuery
args = append(args, pq.args...)
}
return NewQuery(query, args...)
}
// BuildAtomicQuery concatenates the provided queries into a single query wrapped in a BEGIN COMMIT block
func BuildAtomicQuery(queries ...Query) Query {
queries = append([]Query{NewQuery("BEGIN")}, queries...)
queries = append(queries, NewQuery("COMMIT"))
return ConcatenateQueries(queries...)
}