Gorm存在時(shí)更新,不存在時(shí)創(chuàng)建的問題
背景
最近開發(fā)過程中遇到了一個(gè)需求,需要把釘釘組織加架構(gòu)里面的部門信息導(dǎo)入到數(shù)據(jù)庫中。
部門是會(huì)變動(dòng)的,所以如果部門變動(dòng)了,就需要更新一下這張表。
但是無論部門怎么變動(dòng),一個(gè)已經(jīng)存在的部門的id是不會(huì)變的。
所以,當(dāng)釘釘?shù)慕M織架構(gòu)變動(dòng)的時(shí)候,我們需要把老的部門更新,新的部門創(chuàng)建。
我最初想的是,使用if else語句,if dept_id已經(jīng)存在,那就更新,反之則創(chuàng)建,但是我感覺這樣有些不太專業(yè),gorm應(yīng)該會(huì)直接有現(xiàn)成的功能,果然,在我一番搜索之后,終于找到了。
具體實(shí)現(xiàn)
使用一個(gè)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í)行,全部插入

然后我把那個(gè)1手動(dòng)改成2

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

最后附上部門表結(jié)構(gòu)

具體代碼

總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Go Asynq異步任務(wù)處理的實(shí)現(xiàn)
Asynq是一個(gè)新興的異步任務(wù)處理解決方案,它提供了輕量級(jí)的、易于使用的API,本文主要介紹了Go Asynq異步任務(wù)處理的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-06-06
k8s容器互聯(lián)-flannel?host-gw原理篇
這篇文章主要為大家介紹了k8s容器互聯(lián)-flannel?host-gw原理篇,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
多階段構(gòu)建優(yōu)化Go?程序Docker鏡像
這篇文章主要為大家介紹了多階段構(gòu)建優(yōu)化Go?程序Docker鏡像,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
golang動(dòng)態(tài)庫(so)生成與使用方法教程
這篇文章主要給大家介紹了關(guān)于golang動(dòng)態(tài)庫(so)生成與使用的相關(guān)資料,我們平時(shí)使用的動(dòng)態(tài)庫都是由c/c++開發(fā)最后生成的.so文件,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07
使用Go語言實(shí)現(xiàn)找出兩個(gè)大文件中相同的記錄
這篇文章主要為大家詳細(xì)介紹了使用Go語言實(shí)現(xiàn)找出兩個(gè)大文件中相同的記錄的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-10-10

