2023-09-16 02:56:39 +00:00
|
|
|
package database
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
2023-10-14 08:19:04 +00:00
|
|
|
logx "go-admin/logger"
|
2023-09-16 02:56:39 +00:00
|
|
|
"log"
|
|
|
|
"os"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"gorm.io/driver/postgres"
|
|
|
|
"gorm.io/gorm"
|
|
|
|
"gorm.io/gorm/logger"
|
|
|
|
"gorm.io/gorm/schema"
|
|
|
|
|
|
|
|
"go-admin/common/config"
|
|
|
|
"go-admin/common/global"
|
|
|
|
"go-admin/tools"
|
|
|
|
toolsConfig "go-admin/tools/config"
|
|
|
|
)
|
|
|
|
|
|
|
|
type PgSql struct {
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e *PgSql) Setup() {
|
|
|
|
var err error
|
|
|
|
|
|
|
|
global.Source = e.GetConnect()
|
|
|
|
log.Println(global.Source)
|
|
|
|
db, err := sql.Open("postgresql", global.Source)
|
|
|
|
if err != nil {
|
2023-10-14 08:19:04 +00:00
|
|
|
logx.Fatal(tools.Red(e.GetDriver()+" connect error :"), err)
|
2023-09-16 02:56:39 +00:00
|
|
|
}
|
|
|
|
global.Cfg.SetDb(&config.DBConfig{
|
|
|
|
Driver: "mysql",
|
|
|
|
DB: db,
|
|
|
|
})
|
|
|
|
global.Eloquent, err = e.Open(db, &gorm.Config{
|
|
|
|
NamingStrategy: schema.NamingStrategy{
|
|
|
|
SingularTable: true,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("%s connect error %v", e.GetDriver(), err)
|
|
|
|
} else {
|
|
|
|
log.Printf("%s connect success!", e.GetDriver())
|
|
|
|
}
|
|
|
|
|
|
|
|
if global.Eloquent.Error != nil {
|
|
|
|
log.Fatalf("database error %v", global.Eloquent.Error)
|
|
|
|
}
|
|
|
|
|
|
|
|
if toolsConfig.LoggerConfig.EnabledDB {
|
|
|
|
global.Eloquent.Logger = logger.New(log.New(os.Stdout, "\r\n", log.LstdFlags), logger.Config{
|
|
|
|
SlowThreshold: time.Second,
|
|
|
|
Colorful: true,
|
|
|
|
LogLevel: logger.Info,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 打开数据库连接
|
|
|
|
func (e *PgSql) Open(db *sql.DB, cfg *gorm.Config) (*gorm.DB, error) {
|
|
|
|
return gorm.Open(postgres.New(postgres.Config{Conn: db}), cfg)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e *PgSql) GetConnect() string {
|
|
|
|
return toolsConfig.DatabaseConfig.Source
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e *PgSql) GetDriver() string {
|
|
|
|
return toolsConfig.DatabaseConfig.Driver
|
|
|
|
}
|