Go GORM版本2.0新特性介紹
前言
公元2021年3月30日,坊間流傳PHP的git服務(wù)器被黑客攻入,因惡意代碼服務(wù)器將關(guān)停,PHP還是世界上最好的語言嗎?不知道,我是轉(zhuǎn)Go了。
本來是想寫gorm相關(guān)的知識(shí)點(diǎn)的,遇到了批量插入的問題,發(fā)現(xiàn)很不科學(xué),才發(fā)現(xiàn)gorm已經(jīng)出了新版本2.0版本,最新的Tag是v1.21.6,我目前使用的是v1.9.10。
新版本的特性
GORM 2.0 完全從零開始,引入了一些不兼容的 API 變更和許多改進(jìn)。
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
}
還可以方便的創(chuàng)建測(cè)試數(shù)據(jù),使用 CreateInBatches 創(chuàng)建
var users = []User{name: "user_1"}, ...., {Name: "user_10000"}}
// 數(shù)量為 100
db.CreateInBatches(users, 100)
預(yù)編譯模式
預(yù)編譯Sql執(zhí)行語句,以加速后續(xù)的執(zhí)行效率
// 全局模式,所有的操作都會(huì)創(chuàng)建并緩存預(yù)編譯語句,以加速后續(xù)執(zhí)行速度
db, err := gorm.Open(sqlite.Open("gorm.db"), &gorm.Config{PrepareStmt: true})
// 會(huì)話模式,當(dāng)前會(huì)話中的操作會(huì)創(chuàng)建并緩存預(yù)編譯語句
tx := db.Session(&Session{PrepareStmt: true})
tx.First(&user, 1)
tx.Find(&users)
tx.Model(&user).Update("Age", 18)
Joins 預(yù)加載
1.0版本預(yù)加載只能使用Preload,預(yù)加載部分升級(jí)還是比較大的
使用 Inner Join 預(yù)加載關(guān)聯(lián),處理null數(shù)據(jù),避免scan失敗
db.Joins("Company").Joins("Manager").Joins("Account").Find(&users, "users.id IN ?", []int{1,2})
Find to Map
這里讓我想到了Laravel的ORM(Eloquent),它做了一層封裝,支持直接返回集合,而不是PHP常用的數(shù)組
這里的 Find to Map 支持直接把結(jié)果賦值到map集合中,更方便,更靈活
var result map[string]interface{}
db.Model(&User{}).First(&result, "id = ?", 1)
Create From Map
根據(jù) 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)
事務(wù)嵌套
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
})
遠(yuǎn)遠(yuǎn)不止上面這些,更多關(guān)于Go GORM版本2.0特性的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Golang?pprof監(jiān)控之cpu占用率統(tǒng)計(jì)原理詳解
經(jīng)過前面的幾節(jié)對(duì)pprof的介紹,對(duì)pprof統(tǒng)計(jì)的原理算是掌握了七八十了,但唯獨(dú)還沒有分析pprof?工具是如何統(tǒng)計(jì)cpu使用情況的,今天我們來分析下這部分2023-04-04
Golang實(shí)現(xiàn)常見排序算法的示例代碼
現(xiàn)在的面試真的是越來越卷了,算法已經(jīng)成為了面試過程中必不可少的一個(gè)環(huán)節(jié),你如果想進(jìn)稍微好一點(diǎn)的公司,算法是必不可少的一個(gè)環(huán)節(jié)。本文為大家準(zhǔn)備了Golang實(shí)現(xiàn)常見排序算法的示例代碼,需要的可以參考一下2022-05-05
gin解析json格式的數(shù)據(jù)出錯(cuò)的處理方案
這篇文章主要介紹了gin解析json格式的數(shù)據(jù)出錯(cuò)的處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-03-03
詳解Go語言Slice作為函數(shù)參數(shù)的使用
Slice切片在Go語言中實(shí)質(zhì)是一種結(jié)構(gòu)體類型,本文詳細(xì)的介紹了Go語言Slice作為函數(shù)參數(shù)的使用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07

