parent
7165f7f2e5
commit
3a354c2134
@ -0,0 +1,69 @@
|
||||
package gormExample
|
||||
|
||||
import (
|
||||
"gorm.io/driver/mysql"
|
||||
"gorm.io/gorm"
|
||||
"gorm.io/gorm/logger"
|
||||
"gorm.io/gorm/schema"
|
||||
"io"
|
||||
"log"
|
||||
"os"
|
||||
"time"
|
||||
)
|
||||
|
||||
var DB *gorm.DB
|
||||
|
||||
// 配置全局日志级别
|
||||
//func init() {
|
||||
// // 定义DSN
|
||||
// const dsn = "root:secret@tcp(127.0.0.1:3306)/gormExample?charset=utf8mb4&parseTime=True&loc=Local"
|
||||
//
|
||||
// // 连接服务器(池)
|
||||
// db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{
|
||||
// // 设置Info级别的默认日志
|
||||
// Logger: logger.Default.LogMode(logger.Info),
|
||||
// })
|
||||
// if err != nil {
|
||||
// log.Fatal(err)
|
||||
// }
|
||||
//
|
||||
// DB = db
|
||||
//}
|
||||
|
||||
// 自定义日志
|
||||
var logWriter io.Writer
|
||||
|
||||
func init() {
|
||||
// 定义DSN
|
||||
const dsn = "root:secret@tcp(127.0.0.1:3306)/gormExample?charset=utf8mb4&parseTime=True&loc=Local"
|
||||
// 初始化logWriter
|
||||
logWriter, _ = os.OpenFile("./sql.log", os.O_CREATE|os.O_APPEND, 0644)
|
||||
customLogger := logger.New(log.New(logWriter, "\n", log.LstdFlags),
|
||||
logger.Config{
|
||||
// 慢查询阈值 200ms
|
||||
SlowThreshold: 200 * time.Millisecond,
|
||||
// 日志级别
|
||||
LogLevel: logger.Info,
|
||||
// 是否忽略记录不存在的错误
|
||||
IgnoreRecordNotFoundError: false,
|
||||
// 不彩色化
|
||||
Colorful: false,
|
||||
})
|
||||
// 连接服务器(池)
|
||||
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{
|
||||
// 设置为自定义的日志
|
||||
Logger: customLogger,
|
||||
// 设置默认的命名策略的选项
|
||||
NamingStrategy: schema.NamingStrategy{
|
||||
TablePrefix: "msb_",
|
||||
SingularTable: true,
|
||||
NameReplacer: nil,
|
||||
NoLowerCase: false,
|
||||
},
|
||||
})
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
DB = db
|
||||
}
|
@ -0,0 +1,54 @@
|
||||
package gormExample
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"gorm.io/gorm"
|
||||
"log"
|
||||
"time"
|
||||
)
|
||||
|
||||
type Post struct{ gorm.Model }
|
||||
type Category struct{ gorm.Model }
|
||||
type PostCategory struct{ gorm.Model }
|
||||
type Box struct{ gorm.Model }
|
||||
|
||||
func (Box) TableName() string {
|
||||
return "my_box"
|
||||
}
|
||||
|
||||
type TypeMap struct {
|
||||
gorm.Model
|
||||
|
||||
FInt int
|
||||
FUInt uint
|
||||
FFloat32 float32
|
||||
FFloat64 float64
|
||||
FString string
|
||||
FTime time.Time
|
||||
FByteSlice []byte
|
||||
|
||||
FIntP *int
|
||||
FUIntP *uint
|
||||
FFloat32P *float32
|
||||
FFloat64P *float64
|
||||
FStringP *string
|
||||
FTimeP *time.Time
|
||||
}
|
||||
|
||||
func Migrate() {
|
||||
if err := DB.Debug().AutoMigrate(&TypeMap{}, &Post{}, &Category{}, &PostCategory{}, &Box{}); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
}
|
||||
|
||||
func PointerDiff() {
|
||||
// 模型的零值
|
||||
typeMap := &TypeMap{}
|
||||
fmt.Printf("%+v\n", typeMap)
|
||||
|
||||
fmt.Println("=================================")
|
||||
|
||||
// 查询数据NULL对应的值
|
||||
DB.First(typeMap, 1)
|
||||
fmt.Printf("%+v\n", typeMap)
|
||||
}
|
@ -0,0 +1,11 @@
|
||||
package gormExample
|
||||
|
||||
import "testing"
|
||||
|
||||
func TestMigrate(t *testing.T) {
|
||||
Migrate()
|
||||
}
|
||||
|
||||
func TestPointerDiff(t *testing.T) {
|
||||
PointerDiff()
|
||||
}
|
Loading…
Reference in new issue