Files
platform/pkg/orm/orm.go

70 lines
1.3 KiB
Go
Raw Normal View History

2025-03-18 10:13:57 +08:00
package orm
import (
"fmt"
"log/slog"
"platform/pkg/env"
2025-03-18 17:57:07 +08:00
"platform/web/queries"
2025-03-18 10:13:57 +08:00
"gorm.io/gen"
"gorm.io/gen/field"
2025-03-18 10:13:57 +08:00
"gorm.io/gorm"
"gorm.io/gorm/schema"
)
import "gorm.io/driver/postgres"
var DB *gorm.DB
2025-03-18 10:13:57 +08:00
func Init() {
2025-03-18 17:57:07 +08:00
// 连接数据库
2025-03-18 10:13:57 +08:00
dsn := fmt.Sprintf(
"host=%s user=%s password=%s dbname=%s port=%s sslmode=disable TimeZone=Asia/Shanghai",
2025-03-18 17:57:07 +08:00
env.DbHost, env.DbUserName, env.DbPassword, env.DbName, env.DbPort,
2025-03-18 10:13:57 +08:00
)
2025-03-18 17:57:07 +08:00
db, err := gorm.Open(postgres.Open(dsn), &gorm.Config{
2025-03-18 10:13:57 +08:00
NamingStrategy: schema.NamingStrategy{
SingularTable: true,
},
})
if err != nil {
2025-03-18 17:57:07 +08:00
slog.Error("gorm 初始化数据库失败:", slog.Any("err", err))
2025-03-18 10:13:57 +08:00
panic(err)
}
2025-03-18 17:57:07 +08:00
// 连接池
conn, err := db.DB()
2025-03-18 10:13:57 +08:00
if err != nil {
2025-03-18 17:57:07 +08:00
slog.Error("gorm 初始化数据库失败:", slog.Any("err", err))
2025-03-18 10:13:57 +08:00
panic(err)
}
2025-03-18 17:57:07 +08:00
conn.SetMaxIdleConns(10)
conn.SetMaxOpenConns(100)
2025-03-18 10:13:57 +08:00
2025-03-18 17:57:07 +08:00
// 初始化查询工具
queries.SetDefault(db)
DB = db
2025-03-18 10:13:57 +08:00
}
func Exit() error {
if DB != nil {
conn, err := DB.DB()
if err != nil {
return err
}
return conn.Close()
}
return nil
}
type WithAlias interface {
Alias() string
}
func Alias(model WithAlias) func(db gen.Dao) gen.Dao {
return func(db gen.Dao) gen.Dao {
return db.Unscoped().Where(field.NewBool(model.Alias(), "deleted_at").IsNull())
}
}