-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathListBase.go
93 lines (90 loc) · 2.03 KB
/
ListBase.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
package gpa
import (
"database/sql"
"github.com/cihub/seelog"
)
func (dao *Gpa) ListInt64(sqlString string, param ...interface{}) ([]int64, error) {
defer func() {
if err := recover(); err != nil {
seelog.Error("Query fail.\n\t", sqlString , param, "\n", err)
}
}()
rows, err := dao.Conn.Query(sqlString, param...)
defer rows.Close()
if err == nil {
if cols, ec := rows.Columns(); ec == nil {
colLen := len(cols)
if colLen == 1 {
var list []int64
for rows.Next() {
var r sql.NullInt64
rows.Scan(&r)
if r.Valid {
list = append(list, r.Int64)
} else {
list = append(list, 0)
}
}
return list, nil
} else {
for rows.Next() {
arr := make([]interface{}, colLen)
for i := 0; i < colLen; i++ {
var ix sql.NullInt64
arr[i] = &ix
}
es := rows.Scan(arr...)
if es != nil {
seelog.Info("scan int64 fail. ", es)
return nil, es
} else {
var res = make([]int64, colLen)
for i := 0; i < colLen; i++ {
ix := arr[i].(*sql.NullInt64)
if ix.Valid {
res[i] = ix.Int64
}
}
return res, nil
}
}
}
}
}
return nil, nil
}
func (dao *Gpa) ListString(sqlString string, param ...interface{}) ([]string, error) {
defer func() {
if err := recover(); err != nil {
seelog.Error("Query fail.\n\t", sqlString , param, "\n", err)
}
}()
rows, err := dao.Conn.Query(sqlString, param...)
defer rows.Close()
if err == nil {
if cols, ec := rows.Columns(); ec == nil {
colLen := len(cols)
if colLen == 1 {
var list []string
for rows.Next() {
var r sql.NullString
rows.Scan(&r)
list = append(list, r.String)
}
return list, nil
} else {
if rows.Next() {
arr, _ := scan(rows, cols)
resArray := make([]string, colLen)
for i := 0; i < len(cols); i++ {
resArray[i] = arr[i].(*sql.NullString).String
}
return resArray, nil
}
}
}
} else {
seelog.Error("ListString error,", sqlString, param, err)
}
return nil, nil
}