-
Notifications
You must be signed in to change notification settings - Fork 0
/
create.go
91 lines (71 loc) · 1.99 KB
/
create.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
package crud
import (
stdsql "database/sql"
"fmt"
"github.com/azer/crud/v2/sql"
)
func createAndGetResult(exec ExecFn, record interface{}) (stdsql.Result, error) {
row, columns, values, err := valuesForRecord(record)
if err != nil {
return nil, err
}
return exec(sql.InsertQuery(row.SQLTableName, columns), values...)
}
func create(exec ExecFn, record interface{}) error {
_, err := createAndGetResult(exec, record)
return err
}
func createAndRead(exec ExecFn, query QueryFn, record interface{}) error {
result, err := createAndGetResult(exec, record)
if err != nil {
return err
}
return readLastInsert(query, record, result)
}
func replaceAndGetResult(exec ExecFn, record interface{}) (stdsql.Result, error) {
row, columns, values, err := valuesForRecord(record)
if err != nil {
return nil, err
}
return exec(sql.ReplaceQuery(row.SQLTableName, columns), values...)
}
func replace(exec ExecFn, record interface{}) error {
_, err := replaceAndGetResult(exec, record)
return err
}
func replaceAndRead(exec ExecFn, query QueryFn, record interface{}) error {
result, err := replaceAndGetResult(exec, record)
if err != nil {
return err
}
return readLastInsert(query, record, result)
}
func valuesForRecord(record interface{}) (*Row, []string, []interface{}, error) {
row, err := NewRow(record)
if err != nil {
return nil, nil, nil, err
}
columns := []string{}
values := []interface{}{}
for c, v := range row.SQLValues() {
columns = append(columns, c)
values = append(values, v)
}
return row, columns, values, nil
}
func readLastInsert(query QueryFn, record interface{}, result stdsql.Result) error {
id, err := result.LastInsertId()
if err != nil {
return err
}
table, err := NewTable(record)
if err != nil {
// this is a bad design choice made assuming that it'll never happen.
return err
}
params := []interface{}{
fmt.Sprintf("SELECT * FROM %s WHERE %s = ?", table.SQLName, table.PrimaryKeyField().SQL.Name),
id,
}
return read(query, record, params)
}