Go GORM版本2.0新特性介紹
前言
公元2021年3月30日,坊間流傳PHP的git服務(wù)器被黑客攻入,因惡意代碼服務(wù)器將關(guān)停,PHP還是世界上最好的語(yǔ)言嗎?不知道,我是轉(zhuǎn)Go了。
本來(lái)是想寫gorm相關(guān)的知識(shí)點(diǎn)的,遇到了批量插入的問(wèn)題,發(fā)現(xiàn)很不科學(xué),才發(fā)現(xiàn)gorm已經(jīng)出了新版本2.0版本,最新的Tag是v1.21.6,我目前使用的是v1.9.10。
新版本的特性
GORM 2.0 完全從零開(kāi)始,引入了一些不兼容的 API 變更和許多改進(jìn)。
Context 支持
通過(guò) 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í)行語(yǔ)句,以加速后續(xù)的執(zhí)行效率
// 全局模式,所有的操作都會(huì)創(chuàng)建并緩存預(yù)編譯語(yǔ)句,以加速后續(xù)執(zhí)行速度 db, err := gorm.Open(sqlite.Open("gorm.db"), &gorm.Config{PrepareStmt: true}) // 會(huì)話模式,當(dāng)前會(huì)話中的操作會(huì)創(chuàng)建并緩存預(yù)編譯語(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)過(guò)前面的幾節(jié)對(duì)pprof的介紹,對(duì)pprof統(tǒng)計(jì)的原理算是掌握了七八十了,但唯獨(dú)還沒(méi)有分析pprof?工具是如何統(tǒng)計(jì)cpu使用情況的,今天我們來(lái)分析下這部分2023-04-04Golang實(shí)現(xiàn)常見(jiàn)排序算法的示例代碼
現(xiàn)在的面試真的是越來(lái)越卷了,算法已經(jīng)成為了面試過(guò)程中必不可少的一個(gè)環(huán)節(jié),你如果想進(jìn)稍微好一點(diǎn)的公司,算法是必不可少的一個(gè)環(huán)節(jié)。本文為大家準(zhǔn)備了Golang實(shí)現(xiàn)常見(jiàn)排序算法的示例代碼,需要的可以參考一下2022-05-05一文帶你感受Go語(yǔ)言空結(jié)構(gòu)體的魔力
在?Go?語(yǔ)言中,有一種特殊的用法可能讓許多人感到困惑,那就是空結(jié)構(gòu)體,本文將對(duì)Go空結(jié)構(gòu)體進(jìn)行詳解,準(zhǔn)備一杯你最喜歡的飲料或茶,隨著本文一探究竟吧2023-05-05gin解析json格式的數(shù)據(jù)出錯(cuò)的處理方案
這篇文章主要介紹了gin解析json格式的數(shù)據(jù)出錯(cuò)的處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03詳解Go語(yǔ)言Slice作為函數(shù)參數(shù)的使用
Slice切片在Go語(yǔ)言中實(shí)質(zhì)是一種結(jié)構(gòu)體類型,本文詳細(xì)的介紹了Go語(yǔ)言Slice作為函數(shù)參數(shù)的使用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07