欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

gorm FirstOrCreate和受影響的行數(shù)實(shí)例

 更新時(shí)間:2020年12月19日 10:26:12   作者:瘋狂的鴨血  
這篇文章主要介紹了gorm FirstOrCreate和受影響的行數(shù)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

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。類似如下:

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語句。你會(huì)發(fā)現(xiàn),每個(gè)查詢語句都會(huì)有一個(gè)自帶的條件:

where deleted_at is null

也就是說,gorm查詢的時(shí)候是不會(huì)去查詢那些已經(jīng)被軟刪除的記錄的,哪怕你在你的查詢語句里面手動(dòng)加上

where deleted_at is not null

也是無法查詢到的,我試過了,你也可以試試。這也就是軟刪除的作用,查詢是查不到的。

那么問題就來了,我的user_infos表要求用戶名唯一。每次Create記錄的時(shí)候,如果之前已經(jīng)存在一條已經(jīng)被軟刪除的記錄,并且被軟刪除的記錄的user_name與當(dāng)前新增的記錄的user_name相同,那么會(huì)無法新增成功。

報(bào)錯(cuò)類似如下(因?yàn)樽蛱煸诠居龅降模裉熘苣┰诩艺?,無法上圖,等周一可以再來上圖)。

duplicate key for ...

其實(shí)問題就出在軟刪除的記錄那里。

解決:

為了保證以后這條被軟刪除的記錄還能找到(硬刪除就真的再也找不到了),于是就在執(zhí)行軟刪的時(shí)候不調(diào)用Delete方法,而是調(diào)用Update方法,設(shè)置deleted_at為當(dāng)前時(shí)間,并且把需要保持唯一性的字段,比如我這里的用戶名,在原來的用戶名后面加了個(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ò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • Goland編輯器設(shè)置選擇范圍背景色的操作

    Goland編輯器設(shè)置選擇范圍背景色的操作

    這篇文章主要介紹了Goland編輯器設(shè)置選擇范圍背景色的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • Go語言對(duì)字符串進(jìn)行SHA1哈希運(yùn)算的方法

    Go語言對(duì)字符串進(jìn)行SHA1哈希運(yùn)算的方法

    這篇文章主要介紹了Go語言對(duì)字符串進(jìn)行SHA1哈希運(yùn)算的方法,實(shí)例分析了Go語言針對(duì)字符串操作的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-03-03
  • GO開發(fā)編輯器安裝圖文詳解

    GO開發(fā)編輯器安裝圖文詳解

    這篇文章主要介紹了GO開發(fā)編輯器安裝,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • Go語言為什么不支持三元運(yùn)算符原理解析

    Go語言為什么不支持三元運(yùn)算符原理解析

    這篇文章主要為大家介紹了Go語言為什么不支持三元運(yùn)算符原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • Golang?WaitGroup?底層原理及源碼解析

    Golang?WaitGroup?底層原理及源碼解析

    WaitGroup?是?Golang?中最常見的并發(fā)控制技術(shù)之一,它的作用我們可以簡(jiǎn)單類比為其他語言中多線程并發(fā)控制中的?join(),這篇文章主要介紹了Golang?WaitGroup?底層原理及源碼詳解,需要的朋友可以參考下
    2023-04-04
  • Go中的新增對(duì)模糊測(cè)試的支持

    Go中的新增對(duì)模糊測(cè)試的支持

    這篇文章主要為大家介紹了Go中的新增對(duì)模糊測(cè)試的支持,文中還包含了一些功能實(shí)驗(yàn)性測(cè)試分析有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2022-03-03
  • go?字符串修改的操作代碼

    go?字符串修改的操作代碼

    這篇文章主要介紹了go?字符串修改,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • go語言心跳超時(shí)的實(shí)現(xiàn)示例

    go語言心跳超時(shí)的實(shí)現(xiàn)示例

    本文主要介紹了go語言心跳超時(shí)的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • 淺析Go語言中閉包的使用

    淺析Go語言中閉包的使用

    閉包是一個(gè)函數(shù)和其相關(guān)的引用環(huán)境組合的一個(gè)整體。本文主要為大家介紹一下Go語言中閉包的使用,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Go語言有一定幫助,需要的可以參考一下
    2022-12-12
  • Go實(shí)現(xiàn)Redis連接池方法

    Go實(shí)現(xiàn)Redis連接池方法

    為了更深入了解golang連接池的實(shí)現(xiàn),自已又重寫了一遍連接池。文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08

最新評(píng)論