Go GORM版本2.0新特性介紹
前言
公元2021年3月30日,坊間流傳PHP的git服務(wù)器被黑客攻入,因惡意代碼服務(wù)器將關(guān)停,PHP還是世界上最好的語言嗎?不知道,我是轉(zhuǎn)Go了。
本來是想寫gorm相關(guān)的知識點(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)建測試數(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í)行效率
// 全局模式,所有的操作都會創(chuàng)建并緩存預(yù)編譯語句,以加速后續(xù)執(zhí)行速度
db, err := gorm.Open(sqlite.Open("gorm.db"), &gorm.Config{PrepareStmt: true})
// 會話模式,當(dāng)前會話中的操作會創(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ù)加載部分升級還是比較大的
使用 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特性的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Goland使用delve進(jìn)行遠(yuǎn)程調(diào)試的詳細(xì)教程
網(wǎng)上給出的使用delve進(jìn)行遠(yuǎn)程調(diào)試,都需要先在本地交叉編譯或者在遠(yuǎn)程主機(jī)上編譯出可運(yùn)行的程序,然后再用delve在遠(yuǎn)程啟動程序,本教程會將上面的步驟簡化為只需要兩步,1,在遠(yuǎn)程運(yùn)行程序2,在本地啟動調(diào)試,需要的朋友可以參考下2024-08-08
Go語言中實(shí)現(xiàn)完美錯誤處理實(shí)踐分享
Go?語言是一門非常流行的編程語言,由于其高效的并發(fā)編程和出色的網(wǎng)絡(luò)編程能力,越來越受到廣大開發(fā)者的青睞。本文我們就來深入探討一下Go?語言中的錯誤處理機(jī)制吧2023-04-04
golang替換無法顯示的特殊字符(\u0000,?\000,?^@)
這篇文章主要介紹了golang替換無法顯示的特殊字符,包括的字符有\(zhòng)u0000,?\000,?^@等,下文詳細(xì)資料,需要的小伙伴可以參考一下2022-04-04

