91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在gorm中使用FirstOrCreate

發布時間:2020-12-19 16:48:41 來源:億速云 閱讀:3947 作者:Leah 欄目:開發技術

怎么在gorm中使用FirstOrCreate?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

FirstOrCreate

獲取第一個匹配的記錄,或創建一個具有給定條件的新記錄(僅適用于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
 }
 //返回執行結果受影響的行數
 return true, db.RowsAffected
}

補充:gorm踩坑:軟刪除與某個字段的唯一性

有一個user_infos表,用戶名唯一。我在model定義user_name的時候已經使用gorm的tag標記為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"`
}

需求如下:

這個用戶允許刪除,但是又不能真正從db刪掉。

gorm的model如果有deleted_at字段,會默認執行軟刪除。所謂的軟刪除也就是把deleted_at置為當前時間,該記錄并不會從db刪除。

gorm查詢的時候,如果你有仔細查看打印的sql語句。你會發現,每個查詢語句都會有一個自帶的條件:

where deleted_at is null

也就是說,gorm查詢的時候是不會去查詢那些已經被軟刪除的記錄的,哪怕你在你的查詢語句里面手動加上

where deleted_at is not null

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

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

報錯類似如下(因為昨天在公司遇到的,今天周末在家整理,無法上圖,等周一可以再來上圖)。

duplicate key for ...

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

解決:

為了保證以后這條被軟刪除的記錄還能找到(硬刪除就真的再也找不到了),于是就在執行軟刪的時候不調用Delete方法,而是調用Update方法,設置deleted_at為當前時間,并且把需要保持唯一性的字段,比如我這里的用戶名,在原來的用戶名后面加了個時間標記。

如以前的用戶名是張三,現在我刪除的時間是2018-09-15 11:13:06 ,那么我最終將需要刪掉的這條記錄的用戶名設置為張三2018-09-15 11:13:06。

當然這只是個標記而已,你也可以添加你自己的標記,反正最終目的就是為了保證以后這條記錄能被找到。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

民勤县| 旺苍县| 永昌县| 屏山县| 东乌| 丰宁| 房产| 林甸县| 东台市| 丰县| 财经| 五指山市| 伽师县| 雅安市| 城固县| 深圳市| 开化县| 榕江县| 舞钢市| 昌平区| 双柏县| 巴彦县| 勐海县| 乐亭县| 莆田市| 蓝山县| 环江| 永年县| 彭泽县| 阿克陶县| 峨山| 秀山| 元氏县| 汽车| 资讯| 勃利县| 德清县| 鹤岗市| 五台县| 原平市| 尼勒克县|