Upsert:在 GORM 中建立或更新
在 GORM 中,FirstOrCreate 和 FirstOrInit 方法都可以用來檢索或建立資料庫記錄。但是,確定記錄是新建立還是更新可能不清楚。
使用Upsert-On-Conflict 的Upsert 解決方案
從GORM 1.20.x 開始,增強的引入了Upsert 功能,該功能利用各種資料庫的衝突處理功能。
// Update columns when conflict on id DB.Clauses(clause.OnConflict{ Columns: []clause.Column{{Name: "id"}}, DoUpdates: clause.AssignmentColumns([]string{"name", "age"}), }).Create(&users)
此程式碼段轉換為SQL 語句,例如:
- SQL Server:合併到「使用者」中使用*** 不符合時則插入*** 匹配時則更新SET "name"="excluded"."name";
- PostgreSQL: INSERT INTO “用戶”***發生衝突(“id”)時執行更新設定“名稱”=“排除」。 “名稱”,“年齡”=“排除”。 「年齡」;
- MySQL : INSERT INTO 'users' *** ON DUPLICATE KEY UPDATE 'name'=VALUES(name),'age=VALUES(age);
舊版GORM的後備解決方案版本
對於 1.9.x 之前的 GORM 版本,更有效的方法是先嘗試更新,如果沒有找到匹配則創建新記錄。
// Update only set name=nick if err := db.Model(&newUser).Where("id = ?", 3333).Update("name", "nick").Error; err != nil { // Handle error... if gorm.IsRecordNotFoundError(err) { db.Create(&newUser) // Create new record from newUser } }
區分FirstOrInit 和FirstOrCreate
雖然這兩種方法有相似的目的,但它們的行為是不同的:
- FirstOrInit:如果記錄不存在,則初始化結構體存在,但不建立記錄。
- FirstOrCreate:如果不存在則建立記錄,並將記錄檢索到結構體。
以上是與 FirstOrCreate 和 FirstOrInit 相比,GORM 的 Upsert 功能如何運作?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文解釋了GO的軟件包導入機制:命名imports(例如導入“ fmt”)和空白導入(例如導入_ fmt; fmt;)。 命名導入使包裝內容可訪問,而空白導入僅執行t

本文解釋了Beego的NewFlash()函數,用於Web應用程序中的頁間數據傳輸。 它專注於使用newflash()在控制器之間顯示臨時消息(成功,錯誤,警告),並利用會話機制。 Lima

本文詳細介紹了MySQL查詢結果的有效轉換為GO結構切片。 它強調使用數據庫/SQL的掃描方法來最佳性能,避免手動解析。 使用DB標籤和Robus的結構現場映射的最佳實踐

本文演示了創建模擬和存根進行單元測試。 它強調使用接口,提供模擬實現的示例,並討論最佳實踐,例如保持模擬集中並使用斷言庫。 文章

本文探討了GO的仿製藥自定義類型約束。 它詳細介紹了界面如何定義通用功能的最低類型要求,從而改善了類型的安全性和代碼可重複使用性。 本文還討論了局限性和最佳實踐

本文詳細介紹了在GO中詳細介紹有效的文件,將OS.WriteFile(適用於小文件)與OS.openfile和緩衝寫入(最佳大型文件)進行比較。 它強調了使用延遲並檢查特定錯誤的可靠錯誤處理。

本文使用跟踪工具探討了GO應用程序執行流。 它討論了手冊和自動儀器技術,比較諸如Jaeger,Zipkin和Opentelemetry之類的工具,並突出顯示有效的數據可視化


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

禪工作室 13.0.1
強大的PHP整合開發環境

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境