今天是公元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)建測試數(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ù)加載部分升級還是比較大的
- 使用 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集合中,更方便我們輸出結(jié)果甩栈,更靈活
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)不止上面這些泻仙,明天繼續(xù)更新博客。
Last But Not Least
真心感謝帥哥美女們能看到這里量没,如果覺得這篇文章寫得還不錯(cuò)??
求點(diǎn)贊?? 玉转,求關(guān)注?? ,求分享?? 殴蹄,對想成為海賊王的我來說非常有用>孔ァ!饶套!
如果能關(guān)注我公眾號(hào)的話漩蟆,那我比彩票中獎(jiǎng)還高興 ????????