php小編草莓將為您解答如何在關聯不存在時創建關聯。在編程中,我們經常需要使用關聯數組來存儲和操作數據。但有時候我們需要在關聯數組中創建一個新的關聯,但又不希望覆蓋已存在的關聯。這時,我們可以使用條件判斷來實現,只在關聯不存在時才創建新的關聯。這種方法可以保證數據的完整性和準確性,提高代碼的可讀性和可維護性。下面我們來看具體的實現方法。
問題內容
我正在循環遍歷字符串數組,以創建具有該屬性的文檔(僅當該屬性不存在時):
(dbi:我的 gorm 數據庫實例)
var posttags []models.tag for _, tagslug := range tagsarray { tag := models.tag{ slug: tagslug, } err = dbi.where("slug = ?", tagslug).firstorcreate(&tag).error if err != nil { return c.status(fiber.statusinternalservererror).json(fiber.map{ "error": "internal server error", }) } posttags = append(posttags, tag) }
登錄后復制
然后使用這些標簽創建帖子:
post := models.post{ ..., tags: posttags }] dbi.create(&post)
登錄后復制
型號:
type Post struct { BaseModel Title string `json:"title"` MarkdownUploadURL string `json:"markdownUploadUrl"` AuthorID string `json:"authorId"` Tags []Tag `json:"tags" gorm:"many2many:posts_tags"` } type Tag struct { BaseModel Slug string `json:"slug"` }
登錄后復制
我嘗試:將 dbi.firstorcreate()
更改為 dbi.first()
,然后檢查 errors.is(err, gorm.errrecordnotfound
但是每次調用該函數時,我都會得到具有不同 id 的不同標簽,即使它們已經存在于數據庫中……
解決方法
已修復。而不是在帖子中添加標簽,如下所示:
post := models.post{ tags: posttags, } dbi.create(&post)
登錄后復制
我是這樣做的:
post := models.Post { // Other fields (AuthorID, MarkdownUploadURL, Title) } dbi.Create(&post) dbi.Model(&post).Omit("Tags.*").Association("Tags").Append(postTags)
登錄后復制
參考:https://github.com/go-gorm/gorm/issues /3605