/
query.go
101 lines (82 loc) 路 2.62 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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
package cqlquery
import (
"fmt"
"strings"
"github.com/gocql/gocql"
)
// Select creates a select statement.
func Select(table string, fields []string, query map[string]interface{}) *gocql.Query {
var builder strings.Builder
builder.WriteString("SELECT ")
if fields == nil {
builder.WriteString("* ")
} else {
builder.WriteString(strings.Join(fields, ",") + " ")
}
builder.WriteString("FROM " + table + " WHERE ")
var queryFields []string
var values []interface{}
for k, v := range query {
queryFields = append(queryFields, fmt.Sprintf("%s=?", k))
values = append(values, v)
}
builder.WriteString(strings.Join(queryFields, " AND "))
return Conn.Query(builder.String(), values...)
}
// Insert creates an insert statement.
func Insert(table string, query map[string]interface{}) *gocql.Query {
var builder strings.Builder
builder.WriteString("INSERT INTO ")
builder.WriteString(table)
builder.WriteString(" (")
var queryFields []string
var values []interface{}
var valuePlaceholders []string
for k, v := range query {
queryFields = append(queryFields, k)
values = append(values, v)
valuePlaceholders = append(valuePlaceholders, "?")
}
builder.WriteString(strings.Join(queryFields, ","))
builder.WriteString(") VALUES (")
builder.WriteString(strings.Join(valuePlaceholders, ","))
builder.WriteString(")")
return Conn.Query(builder.String(), values...)
}
// Update creates an update statement.
func Update(table string, query map[string]interface{}, changes map[string]interface{}) *gocql.Query {
var builder strings.Builder
builder.WriteString("UPDATE ")
builder.WriteString(table)
builder.WriteString(" SET ")
var changeFields []string
var values []interface{}
for k, v := range changes {
changeFields = append(changeFields, fmt.Sprintf("%s=?", k))
values = append(values, v)
}
builder.WriteString(strings.Join(changeFields, ","))
builder.WriteString(" WHERE ")
var queryFields []string
for k, v := range query {
queryFields = append(queryFields, fmt.Sprintf("%s=?", k))
values = append(values, v)
}
builder.WriteString(strings.Join(queryFields, " AND "))
return Conn.Query(builder.String(), values...)
}
// Delete creates an insert statement.
func Delete(table string, query map[string]interface{}) *gocql.Query {
var builder strings.Builder
builder.WriteString("DELETE FROM ")
builder.WriteString(table)
builder.WriteString(" WHERE ")
var fields []string
var values []interface{}
for k, v := range query {
fields = append(fields, fmt.Sprintf("%s=?", k))
values = append(values, v)
}
builder.WriteString(strings.Join(fields, " AND "))
return Conn.Query(builder.String(), values...)
}