gorm FirstOrCreate和受影響的行數(shù)實(shí)例
FirstOrCreate
獲取第一個(gè)匹配的記錄,或創(chuàng)建一個(gè)具有給定條件的新記錄(僅適用于struct, map條件)
db.Where(User{Name: "Jinzhu"}).FirstOrCreate(&user)
代碼案例:
func (tsu *TopicSignUp) TopicSignUpCreate() (bool, int64) {
db := Db.Where(tsu).FirstOrCreate(&tsu)
if err := db.Error; err != nil {
return false, 0
}
//返回執(zhí)行結(jié)果受影響的行數(shù)
return true, db.RowsAffected
}
補(bǔ)充:gorm踩坑:軟刪除與某個(gè)字段的唯一性
有一個(gè)user_infos表,用戶名唯一。我在model定義user_name的時(shí)候已經(jīng)使用gorm的tag標(biāo)記為unique_index。類(lèi)似如下:
type UserInfo struct {
Id uint `json:id`
Created_at tine.Time `josn:"created_at"`
Updated_at time.Time `json:"updated_at"`
DeletedAt *time.Time `json:"deleted_at"`
UserName string `gorm:"unique_index, not null" json:"user_name"`
}
需求如下:
這個(gè)用戶允許刪除,但是又不能真正從db刪掉。
gorm的model如果有deleted_at字段,會(huì)默認(rèn)執(zhí)行軟刪除。所謂的軟刪除也就是把deleted_at置為當(dāng)前時(shí)間,該記錄并不會(huì)從db刪除。
gorm查詢的時(shí)候,如果你有仔細(xì)查看打印的sql語(yǔ)句。你會(huì)發(fā)現(xiàn),每個(gè)查詢語(yǔ)句都會(huì)有一個(gè)自帶的條件:
where deleted_at is null
也就是說(shuō),gorm查詢的時(shí)候是不會(huì)去查詢那些已經(jīng)被軟刪除的記錄的,哪怕你在你的查詢語(yǔ)句里面手動(dòng)加上
where deleted_at is not null
也是無(wú)法查詢到的,我試過(guò)了,你也可以試試。這也就是軟刪除的作用,查詢是查不到的。
那么問(wèn)題就來(lái)了,我的user_infos表要求用戶名唯一。每次Create記錄的時(shí)候,如果之前已經(jīng)存在一條已經(jīng)被軟刪除的記錄,并且被軟刪除的記錄的user_name與當(dāng)前新增的記錄的user_name相同,那么會(huì)無(wú)法新增成功。
報(bào)錯(cuò)類(lèi)似如下(因?yàn)樽蛱煸诠居龅降模裉熘苣┰诩艺?,無(wú)法上圖,等周一可以再來(lái)上圖)。
duplicate key for ...
其實(shí)問(wèn)題就出在軟刪除的記錄那里。
解決:
為了保證以后這條被軟刪除的記錄還能找到(硬刪除就真的再也找不到了),于是就在執(zhí)行軟刪的時(shí)候不調(diào)用Delete方法,而是調(diào)用Update方法,設(shè)置deleted_at為當(dāng)前時(shí)間,并且把需要保持唯一性的字段,比如我這里的用戶名,在原來(lái)的用戶名后面加了個(gè)時(shí)間標(biāo)記。
如以前的用戶名是張三,現(xiàn)在我刪除的時(shí)間是2018-09-15 11:13:06 ,那么我最終將需要?jiǎng)h掉的這條記錄的用戶名設(shè)置為張三2018-09-15 11:13:06。
當(dāng)然這只是個(gè)標(biāo)記而已,你也可以添加你自己的標(biāo)記,反正最終目的就是為了保證以后這條記錄能被找到。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
- gorm update傳入struct對(duì)象,零值字段不更新的解決方案
- gorm操作MySql數(shù)據(jù)庫(kù)的方法
- Go基于GORM 獲取當(dāng)前請(qǐng)求所執(zhí)行的 SQL 信息(思路詳解)
- Golang 使用gorm添加數(shù)據(jù)庫(kù)排他鎖,for update
- golang Gorm與數(shù)據(jù)庫(kù)完整性約束詳解
- golang gorm 結(jié)構(gòu)體的表字段缺省值設(shè)置方式
- golang gorm 計(jì)算字段和獲取sum()值的實(shí)現(xiàn)
- 解決Go gorm踩過(guò)的坑
相關(guān)文章
go語(yǔ)言中使用ent做關(guān)聯(lián)查詢的示例詳解
go語(yǔ)言的ent框架是facebook開(kāi)源的ORM框架,是go語(yǔ)言開(kāi)發(fā)中的常用框架,而關(guān)聯(lián)查詢又是日常開(kāi)發(fā)中的常見(jiàn)數(shù)據(jù)庫(kù)操作,故文本給出一個(gè)使用ent做關(guān)聯(lián)查詢的使用示例,需要的朋友可以參考下2024-02-02
go語(yǔ)言實(shí)現(xiàn)聊天服務(wù)器的示例代碼
這篇文章主要介紹了go語(yǔ)言實(shí)現(xiàn)聊天服務(wù)器的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
手把手帶你走進(jìn)Go語(yǔ)言之運(yùn)算符解析
這篇文章主要介紹了手Go語(yǔ)言之運(yùn)算符解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
GoFrame實(shí)現(xiàn)順序性校驗(yàn)示例詳解
這篇文章主要為大家介紹了GoFrame實(shí)現(xiàn)順序性校驗(yàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
Air實(shí)現(xiàn)Go程序?qū)崟r(shí)熱重載使用過(guò)程解析示例
這篇文章主要為大家介紹了Air實(shí)現(xiàn)Go程序?qū)崟r(shí)熱重載使用過(guò)程解析示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04
Go?slice切片make生成append追加copy復(fù)制示例
這篇文章主要為大家介紹了Go使用make生成切片、使用append追加切片元素、使用copy復(fù)制切片使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
解決golang處理http response碰到的問(wèn)題和需要注意的點(diǎn)
這篇文章主要介紹了解決golang處理http response碰到的問(wèn)題和需要注意的點(diǎn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12
Go語(yǔ)言實(shí)現(xiàn)的可讀性更高的并發(fā)神庫(kù)詳解
這篇文章主要為大家介紹了Go語(yǔ)言實(shí)現(xiàn)的可讀性更高的并發(fā)神庫(kù)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01

