-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathcreate.go
55 lines (43 loc) · 1.08 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
package crud
import (
stdsql "database/sql"
"fmt"
"github.com/azer/crud/v2/sql"
)
func createAndGetResult(exec ExecFn, record interface{}) (stdsql.Result, error) {
row, err := newRow(record)
if err != nil {
return nil, err
}
columns := []string{}
values := []interface{}{}
for c, v := range row.SQLValues() {
columns = append(columns, c)
values = append(values, v)
}
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
}
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)
}