| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546 |
- package orm
- import (
- "fmt"
- "github.com/lejianwen/rustdesk-api/global"
- "gorm.io/driver/sqlite"
- "gorm.io/gorm"
- "gorm.io/gorm/logger"
- "time"
- )
- type SqliteConfig struct {
- MaxIdleConns int
- MaxOpenConns int
- }
- func NewSqlite(sqliteConf *SqliteConfig) *gorm.DB {
- db, err := gorm.Open(sqlite.Open("./data/rustdeskapi.db"), &gorm.Config{
- DisableForeignKeyConstraintWhenMigrating: true,
- Logger: logger.New(
- global.Logger, // io writer
- logger.Config{
- SlowThreshold: time.Second, // Slow SQL threshold
- LogLevel: logger.Warn, // Log level
- IgnoreRecordNotFoundError: true, // Ignore ErrRecordNotFound error for logger
- ParameterizedQueries: true, // Don't include params in the SQL log
- Colorful: true,
- },
- ),
- })
- if err != nil {
- fmt.Println(err)
- }
- sqlDB, err2 := db.DB()
- if err2 != nil {
- fmt.Println(err2)
- }
- // SetMaxIdleConns 设置空闲连接池中连接的最大数量
- sqlDB.SetMaxIdleConns(sqliteConf.MaxIdleConns)
- // SetMaxOpenConns 设置打开数据库连接的最大数量。
- sqlDB.SetMaxOpenConns(sqliteConf.MaxOpenConns)
- return db
- }
|