欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Gorm存在時(shí)更新,不存在時(shí)創(chuàng)建的問(wèn)題

 更新時(shí)間:2024年08月08日 14:47:32   作者:大杯無(wú)糖  
這篇文章主要介紹了Gorm存在時(shí)更新,不存在時(shí)創(chuàng)建的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

背景

最近開(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每日一庫(kù)之quicktemplate的使用

    Go每日一庫(kù)之quicktemplate的使用

    quicktemplate快速、功能強(qiáng)大、易于使用的Go模板引擎。比html/模板快20倍,本文我們就詳細(xì)的介紹一下quicktemplate的具體使用,感興趣的可以了解一下
    2021-07-07
  • Go語(yǔ)言判斷文件或文件夾是否存在的方法

    Go語(yǔ)言判斷文件或文件夾是否存在的方法

    這篇文章主要介紹了Go語(yǔ)言判斷文件或文件夾是否存在的方法,結(jié)合具體實(shí)例形式對(duì)比分析了Go語(yǔ)言針對(duì)文件與目錄判斷的操作技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2017-05-05
  • Go Asynq異步任務(wù)處理的實(shí)現(xià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ù)解析指南

    從入門(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-03
  • Golang中多個(gè)if代碼優(yōu)化小技巧

    Golang中多個(gè)if代碼優(yōu)化小技巧

    這篇文章主要為大家詳細(xì)介紹了Golang中一些常用的if代碼優(yōu)化小技巧,w文中的示例代碼簡(jiǎn)潔易懂,具有一定的借鑒價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-10-10
  • k8s容器互聯(lián)-flannel?host-gw原理篇

    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鏡像

    這篇文章主要為大家介紹了多階段構(gòu)建優(yōu)化Go?程序Docker鏡像,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • golang中獲取變量類(lèi)型的方法總結(jié)

    golang中獲取變量類(lèi)型的方法總結(jié)

    golang中是沒(méi)有提供內(nèi)置函數(shù)來(lái)獲取變量的類(lèi)型的,但是通過(guò)一定的方式也可以獲取,下面主要給大家介紹了幾個(gè)golang獲取變量類(lèi)型的幾種方式,需要的朋友可以參考下
    2025-03-03
  • golang動(dòng)態(tài)庫(kù)(so)生成與使用方法教程

    golang動(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è)大文件中相同的記錄

    使用Go語(yǔ)言實(shí)現(xiàn)找出兩個(gè)大文件中相同的記錄

    這篇文章主要為大家詳細(xì)介紹了使用Go語(yǔ)言實(shí)現(xiàn)找出兩個(gè)大文件中相同的記錄的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-10-10

最新評(píng)論