qixiaoning
2025-07-08 84d2ef9760af0a4a4aa933937294400b3caa291d
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
package models
 
import (
    "basic.com/valib/logger.git"
    "gorm.io/driver/sqlite"
    "gorm.io/gorm"
    "strings"
)
 
var (
    db             *gorm.DB
    DeviceInfo     Device
    IntervalConfig Interval
)
 
func Init(dbPath string) {
    var err error
 
    db, err = gorm.Open(sqlite.Open(dbPath), &gorm.Config{})
 
    if err != nil {
        logger.Debug("db open error ", err)
        return
    }
    _ = db.AutoMigrate(Device{}, Interval{})
 
    // 添加时间间隔默认数据
    var sqls []string
    sqls = append(sqls, "INSERT INTO t_interval(`id`,`devInfo`,`DevState`) SELECT 'default',1440,10 where not exists (select 1 from t_interval);")
    db.Exec(strings.Join(sqls, ""))
 
    DeviceInfo.Read()
    IntervalConfig.Read()
 
    logger.Debug("DeviceInfo:", DeviceInfo, " IntervalConfig", IntervalConfig)
}
 
func GetDB() *gorm.DB {
    return db
}
 
func CloseDB() {
 
}