Gorm存在時(shí)更新,不存在時(shí)創(chuàng)建的問(wèn)題
背景
最近開(kāi)發(fā)過(guò)程中遇到了一個(gè)需求,需要把釘釘組織加架構(gòu)里面的部門(mén)信息導(dǎo)入到數(shù)據(jù)庫(kù)中。
部門(mén)是會(huì)變動(dòng)的,所以如果部門(mén)變動(dòng)了,就需要更新一下這張表。
但是無(wú)論部門(mén)怎么變動(dòng),一個(gè)已經(jīng)存在的部門(mén)的id是不會(huì)變的。
所以,當(dāng)釘釘?shù)慕M織架構(gòu)變動(dòng)的時(shí)候,我們需要把老的部門(mén)更新,新的部門(mén)創(chuàng)建。
我最初想的是,使用if else語(yǔ)句,if dept_id已經(jīng)存在,那就更新,反之則創(chuàng)建,但是我感覺(jué)這樣有些不太專(zhuān)業(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,那就代表成功了
最后附上部門(mén)表結(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從入門(mén)到精通:Go語(yǔ)言XML數(shù)據(jù)解析指南
Go語(yǔ)言的XML包提供了強(qiáng)大的數(shù)據(jù)解析功能,讓你輕松處理各種XML格式的數(shù)據(jù),這個(gè)指南將帶你深入了解如何使用Go語(yǔ)言的XML包,快速上手XML數(shù)據(jù)解析,準(zhǔn)備好開(kāi)啟XML解析之旅了嗎?Let's?Go!2024-03-03k8s容器互聯(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-08golang動(dòng)態(tài)庫(kù)(so)生成與使用方法教程
這篇文章主要給大家介紹了關(guān)于golang動(dòng)態(tài)庫(kù)(so)生成與使用的相關(guān)資料,我們平時(shí)使用的動(dòng)態(tài)庫(kù)都是由c/c++開(kāi)發(fā)最后生成的.so文件,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07使用Go語(yǔ)言實(shí)現(xiàn)找出兩個(gè)大文件中相同的記錄
這篇文章主要為大家詳細(xì)介紹了使用Go語(yǔ)言實(shí)現(xiàn)找出兩個(gè)大文件中相同的記錄的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-10-10