日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Go?GORM版本2.0新特性介紹_Golang

作者:王中陽Go ? 更新時間: 2022-08-03 編程語言

前言

公元2021年3月30日,坊間流傳PHP的git服務器被黑客攻入,因惡意代碼服務器將關停,PHP還是世界上最好的語言嗎?不知道,我是轉Go了。

本來是想寫gorm相關的知識點的,遇到了批量插入的問題,發現很不科學,才發現gorm已經出了新版本2.0版本,最新的Tag是v1.21.6,我目前使用的是v1.9.10。

新版本的特性

GORM 2.0 完全從零開始,引入了一些不兼容的 API 變更和許多改進。

Context 支持

通過 WithContext 方法提供 context.Context 支持

db.WithContext(ctx).Find(&users)

批量插入

老版本的批量插入很是惡心,新版本還是非常友好的

我們可以直接將切片slice傳遞給Create方法

var users = []User{{Name: "user1"}, {Name: "user2"}, {Name: "user3"}}
db.Create(&users)
for _, user := range users {
  user.ID // 1,2,3
}

還可以方便的創建測試數據,使用 CreateInBatches 創建

var users = []User{name: "user_1"}, ...., {Name: "user_10000"}}
// 數量為 100
db.CreateInBatches(users, 100)

預編譯模式

預編譯Sql執行語句,以加速后續的執行效率

// 全局模式,所有的操作都會創建并緩存預編譯語句,以加速后續執行速度
db, err := gorm.Open(sqlite.Open("gorm.db"), &gorm.Config{PrepareStmt: true})
// 會話模式,當前會話中的操作會創建并緩存預編譯語句
tx := db.Session(&Session{PrepareStmt: true})
tx.First(&user, 1)
tx.Find(&users)
tx.Model(&user).Update("Age", 18)

Joins 預加載

1.0版本預加載只能使用Preload,預加載部分升級還是比較大的

使用 Inner Join 預加載關聯,處理null數據,避免scan失敗

db.Joins("Company").Joins("Manager").Joins("Account").Find(&users, "users.id IN ?", []int{1,2})

Find to Map

這里讓我想到了Laravel的ORM(Eloquent),它做了一層封裝,支持直接返回集合,而不是PHP常用的數組

這里的 Find to Map 支持直接把結果賦值到map集合中,更方便,更靈活

var result map[string]interface{}
db.Model(&User{}).First(&result, "id = ?", 1)

Create From Map

根據 map[string]interface{} 或 []map[string]interface{} Create

//map[string]interface{} 示例
db.Model(&User{}).Create(map[string]interface{}{"Name": "user", "Age": 18})
//[]map[string]interface{} Create 示例
datas := []map[string]interface{}{
  {"Name": "user_1", "Age": 19},
  {"name": "user_2", "Age": 20},
}
db.Model(&User{}).Create(datas)

事務嵌套

db.Transaction(func(tx *gorm.DB) error {
  tx.Create(&user1)
  tx.Transaction(func(tx2 *gorm.DB) error {
    tx.Create(&user2)
    return errors.New("rollback user2") // rollback user2
  })
  tx.Transaction(func(tx2 *gorm.DB) error {
    tx.Create(&user3)
    return nil
  })
  return nil // commit user1 and user3
})

原文鏈接:https://juejin.cn/post/6945404499850854408

欄目分類
最近更新