Gorm存在時更新,不存在時創(chuàng)建的問題
更新時間:2024年08月08日 14:47:32 作者:大杯無糖
這篇文章主要介紹了Gorm存在時更新,不存在時創(chuàng)建的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
背景
最近開發(fā)過程中遇到了一個需求,需要把釘釘組織加架構里面的部門信息導入到數(shù)據(jù)庫中。
部門是會變動的,所以如果部門變動了,就需要更新一下這張表。
但是無論部門怎么變動,一個已經(jīng)存在的部門的id是不會變的。
所以,當釘釘?shù)慕M織架構變動的時候,我們需要把老的部門更新,新的部門創(chuàng)建。
我最初想的是,使用if else語句,if dept_id已經(jīng)存在,那就更新,反之則創(chuàng)建,但是我感覺這樣有些不太專業(yè),gorm應該會直接有現(xiàn)成的功能,果然,在我一番搜索之后,終于找到了。
具體實現(xiàn)
使用一個gorm操作,智能化的完成上面操作。 我們就可以用到Upsert 了。
創(chuàng)建 | GORM - The fantastic ORM library for Golang, aims to be developer friendly.

上面的一句英文 Update columns to new value on `id` conflict 意思是:
如果id已經(jīng)存在了,那我就更新,反之id不存在,那我就插入。
第一次執(zhí)行,全部插入

然后我把那個1手動改成2

然后再去使用釘釘接口獲取一次,這個使用如果只有這個2變成了1,那就代表成功了

最后附上部門表結構

具體代碼

總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Go每日一庫之quicktemplate的使用
quicktemplate快速、功能強大、易于使用的Go模板引擎。比html/模板快20倍,本文我們就詳細的介紹一下quicktemplate的具體使用,感興趣的可以了解一下
2021-07-07
Go語言判斷文件或文件夾是否存在的方法
這篇文章主要介紹了Go語言判斷文件或文件夾是否存在的方法,結合具體實例形式對比分析了Go語言針對文件與目錄判斷的操作技巧與相關注意事項,需要的朋友可以參考下
2017-05-05
Go Asynq異步任務處理的實現(xiàn)
Asynq是一個新興的異步任務處理解決方案,它提供了輕量級的、易于使用的API,本文主要介紹了Go Asynq異步任務處理的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
2023-06-06
從入門到精通:Go語言XML數(shù)據(jù)解析指南
Go語言的XML包提供了強大的數(shù)據(jù)解析功能,讓你輕松處理各種XML格式的數(shù)據(jù),這個指南將帶你深入了解如何使用Go語言的XML包,快速上手XML數(shù)據(jù)解析,準備好開啟XML解析之旅了嗎?Let's?Go!
2024-03-03
Golang中多個if代碼優(yōu)化小技巧
這篇文章主要為大家詳細介紹了Golang中一些常用的if代碼優(yōu)化小技巧,w文中的示例代碼簡潔易懂,具有一定的借鑒價值,感興趣的小伙伴可以跟隨小編一起學習一下
2023-10-10
golang中獲取變量類型的方法總結
golang中是沒有提供內(nèi)置函數(shù)來獲取變量的類型的,但是通過一定的方式也可以獲取,下面主要給大家介紹了幾個golang獲取變量類型的幾種方式,需要的朋友可以參考下
2025-03-03
golang動態(tài)庫(so)生成與使用方法教程
這篇文章主要給大家介紹了關于golang動態(tài)庫(so)生成與使用的相關資料,我們平時使用的動態(tài)庫都是由c/c++開發(fā)最后生成的.so文件,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
2023-07-07