-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathwrapper.go
More file actions
117 lines (94 loc) · 2.49 KB
/
wrapper.go
File metadata and controls
117 lines (94 loc) · 2.49 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
package lazydb
import (
"database/sql"
"fmt"
)
// Container for create & execute prepared statements. Read only after creation.
type ParamQuery struct {
Query string
Args []any
}
// Create ParamQuery by given parameters. Value are not able to modify after creation.
func Param(query string, args ...any) ParamQuery {
return ParamQuery{
Query: query,
Args: args,
}
}
// Return filled version of query.
func (p *ParamQuery) Filled() string {
return asFilledQuery(p.Query, p.Args...)
}
// ----------------------------------------------------------------
// Execute given query, by prepared statement.
func (l *LazyDB) Exec(query string, args ...any) (sql.Result, error) {
if l.db == nil {
return nil, ErrNilDatabase
}
stmt, err := l.db.Prepare(query)
if err != nil {
return nil, err
}
return stmt.Exec(args...)
}
// Execute given query, by prepared statement & transaction.
//
// Any failed query will cause a rollback, and return nil []sql.Result.
// Only all queries successful will return valid sql.Result slices.
func (l *LazyDB) ExecMultiple(pQueries []ParamQuery) ([]sql.Result, error) {
if l.db == nil {
return nil, ErrNilDatabase
}
if pQueries == nil {
return nil, ErrEmptyStmt
}
results := make([]sql.Result, 0)
// Begin transaction
tx, err := l.db.Begin()
if err != nil {
return nil, err
}
defer tx.Rollback() // Any failed tx will cause rollback
// Exec query with prepare statement
for _, query := range pQueries {
stmt, err := tx.Prepare(query.Query)
if err != nil {
return nil, fmt.Errorf("failed to prepare '%s': %v", query.Query, err)
}
result, err := stmt.Exec(query.Args...)
if err != nil {
return nil, fmt.Errorf("failed to exec '%s' with (%v): %v", query.Query, query.Args, err)
}
// Record result of query
results = append(results, result)
}
// Commit
err = tx.Commit()
if err != nil {
return nil, err
}
// Only return results when no errors
return results, nil
}
// Wrapper for Query() function, using prepared statement.
func (l *LazyDB) Query(query string, args ...any) (*sql.Rows, error) {
if l.db == nil {
return nil, ErrNilDatabase
}
stmt, err := l.db.Prepare(query)
if err != nil {
return nil, err
}
return stmt.Query(args...)
}
// Wrapper for QueryRow() function, using prepared statement.
func (l *LazyDB) QueryRow(query string, args ...any) (*sql.Row, error) {
if l.db == nil {
return nil, ErrNilDatabase
}
stmt, err := l.db.Prepare(query)
if err != nil {
return nil, err
}
return stmt.QueryRow(args...), nil
}