mirror of
https://github.com/YFGaia/dify-plus.git
synced 2026-06-04 10:14:00 +08:00
59 lines
1.5 KiB
Go
59 lines
1.5 KiB
Go
package initialize
|
|
|
|
import (
|
|
"github.com/flipped-aurora/gin-vue-admin/server/config"
|
|
"github.com/flipped-aurora/gin-vue-admin/server/global"
|
|
"github.com/flipped-aurora/gin-vue-admin/server/initialize/internal"
|
|
"gorm.io/driver/postgres"
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
// GormPgSql 初始化 Postgresql 数据库
|
|
// Author [piexlmax](https://github.com/piexlmax)
|
|
// Author [SliverHorn](https://github.com/SliverHorn)
|
|
func GormPgSql() *gorm.DB {
|
|
p := global.GVA_CONFIG.Pgsql
|
|
if p.Dbname == "" {
|
|
return nil
|
|
}
|
|
pgsqlConfig := postgres.Config{
|
|
DSN: p.Dsn(), // DSN data source name
|
|
PreferSimpleProtocol: false,
|
|
}
|
|
if db, err := gorm.Open(postgres.New(pgsqlConfig), internal.Gorm.Config(p.Prefix, p.Singular)); err != nil {
|
|
return nil
|
|
} else {
|
|
sqlDB, _ := db.DB()
|
|
sqlDB.SetMaxIdleConns(p.MaxIdleConns)
|
|
sqlDB.SetMaxOpenConns(p.MaxOpenConns)
|
|
|
|
// 为PostgreSQL创建必要的序列
|
|
//createPostgreSQLSequences(db)
|
|
|
|
return db
|
|
}
|
|
}
|
|
|
|
// GormPgSqlByConfig 初始化 Postgresql 数据库 通过参数
|
|
func GormPgSqlByConfig(p config.Pgsql) *gorm.DB {
|
|
if p.Dbname == "" {
|
|
return nil
|
|
}
|
|
pgsqlConfig := postgres.Config{
|
|
DSN: p.Dsn(), // DSN data source name
|
|
PreferSimpleProtocol: false,
|
|
}
|
|
if db, err := gorm.Open(postgres.New(pgsqlConfig), internal.Gorm.Config(p.Prefix, p.Singular)); err != nil {
|
|
panic(err)
|
|
} else {
|
|
sqlDB, _ := db.DB()
|
|
sqlDB.SetMaxIdleConns(p.MaxIdleConns)
|
|
sqlDB.SetMaxOpenConns(p.MaxOpenConns)
|
|
|
|
// 为PostgreSQL创建必要的序列
|
|
//createPostgreSQLSequences(db)
|
|
|
|
return db
|
|
}
|
|
}
|