-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkey-value.go
62 lines (56 loc) · 1.42 KB
/
key-value.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
package lightweight_db
import (
"github.com/ssst0n3/awesome_libs"
"github.com/ssst0n3/awesome_libs/awesome_error"
"strconv"
)
type Config struct {
Key string `json:"key"`
Value string `json:"value"`
}
const (
TableNameConfig = "config"
ColumnNameConfigKey = "key"
ColumnNameConfigValue = "value"
)
func (c Connector) CreateTableConfig() (err error) {
query := `CREATE TABLE IF NOT EXISTS config(
key text primary key,
value text
);`
statement, err := c.DB.Prepare(query)
if err != nil {
awesome_error.CheckFatal(err)
return
}
_, err = statement.Exec()
awesome_error.CheckErr(err)
return
}
func (c Connector) KVGetValueByKey(tableName, columnNameValue, columnNameKey, columnKey string) (value string, err error) {
var config Config
query := awesome_libs.Format("SELECT {.value} FROM {.tbl} WHERE {.key}=? LIMIT 1", awesome_libs.Dict{
"value": columnNameValue,
"tbl": tableName,
"key": columnNameKey,
})
err = c.OrmQueryRowBind(&config, query, columnKey)
value = config.Value
return
}
func (c Connector) ShouldInitialize() (shouldInitialize bool, err error) {
value, err := c.KVGetValueByKey(
TableNameConfig, ColumnNameConfigValue, ColumnNameConfigKey, "is_initialized",
)
if err != nil {
return
}
if isInitialized, err := strconv.ParseBool(value); err != nil {
awesome_error.CheckDebug(err)
shouldInitialize = true
err = nil
} else {
shouldInitialize = !isInitialized
}
return
}