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

Go語言中使用gorm小結(jié)

 更新時(shí)間:2016年12月07日 08:40:23   投稿:daisy  
這篇文章主要給大家介紹了Go語言中如何使用gorm,文中介紹的很詳細(xì),有需要的朋友們可以參考借鑒,下面來一起看看吧。

首先說明的是,在項(xiàng)目中使用orm的好處很多:

  1. 防止直接拼接sql語句引入sql注入漏洞
  2. 方便對(duì)modle進(jìn)行統(tǒng)一管理
  3. 專注業(yè)務(wù),加速開發(fā)

壞處也是顯而易見的:

  1. 開發(fā)者與最終的sql語句隔了一層orm,因此可能會(huì)不慎引入爛sql
  2. 依賴于orm的成熟度,無法進(jìn)行一些「復(fù)雜」的查詢。當(dāng)然,復(fù)雜的查詢一大半都是應(yīng)該從設(shè)計(jì)上規(guī)避的

留意不合法的時(shí)間值

MySQL的DATE/DATATIME類型可以對(duì)應(yīng)Golang的time.Time。但是,如果DATE/DATATIME不慎插入了一個(gè)無效值,例如2016-00-00 00:00:00, 那么這條記錄是無法查詢出來的。會(huì)返回gorm.RecordNotFound類型錯(cuò)誤。零值0000-00-00 00:00:00是有效值,不影響正常查詢。

留意tagsql:"default:null"

gorm對(duì)各種tag的支持非常完善。但是有些行為跟直覺不太一致,需要注意。當(dāng)對(duì)某字段設(shè)置tagsql:"default:null"時(shí),你想通過update設(shè)置該字段為null就不可能了,只能通過raw sql。這是gorm設(shè)計(jì)的取向問題。

如何通過gorm設(shè)置字段為null值

字段允許為null值肯定是設(shè)計(jì)存在問題。但是,往往前人埋下的坑需要你去填。gorm作者給出了兩種方法,以string為例:

在golang中,聲明該字段為*string

使用sql.NullString類型

推薦使用后者。

留意連接串中的loc

例如通過如下連接串打開mysql連接:

復(fù)制代碼 代碼如下:

db, err := gorm.Open("mysql", "db:dbadmin@tcp(127.0.0.1:3306)/foo?charset=utf8&parseTime=true&loc=Local")

parseTime=true&loc=Local說明會(huì)解析時(shí)間,時(shí)區(qū)是機(jī)器的local時(shí)區(qū)。機(jī)器之間的時(shí)區(qū)可能不一致會(huì)設(shè)置有問題,這導(dǎo)致從相同庫的不同實(shí)例查詢出來的結(jié)果可能解析以后就不一樣。因此推薦將loc統(tǒng)一設(shè)置為一個(gè)時(shí)區(qū),如parseTime=true&loc=America%2FChicago

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

相關(guān)文章

  • Golang?手寫一個(gè)簡(jiǎn)單的并發(fā)任務(wù)?manager

    Golang?手寫一個(gè)簡(jiǎn)單的并發(fā)任務(wù)?manager

    這篇文章主要介紹了Golang?手寫一個(gè)簡(jiǎn)單的并發(fā)任務(wù)?manager,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • go-kit組件使用hystrix中間件的操作

    go-kit組件使用hystrix中間件的操作

    這篇文章主要介紹了go-kit組件使用hystrix中間件的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • Go逃逸分析示例詳解

    Go逃逸分析示例詳解

    這篇文章主要為大家介紹了Go逃逸分析示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • gtoken替換jwt實(shí)現(xiàn)sso登錄的問題小結(jié)

    gtoken替換jwt實(shí)現(xiàn)sso登錄的問題小結(jié)

    這篇文章主要介紹了gtoken替換jwt實(shí)現(xiàn)sso登錄,主要介紹了替換jwt的原因分析及gtoken的優(yōu)勢(shì),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • Go設(shè)計(jì)模式之策略模式講解和代碼示例

    Go設(shè)計(jì)模式之策略模式講解和代碼示例

    策略是一種行為設(shè)計(jì)模式,?它將一組行為轉(zhuǎn)換為對(duì)象,?并使其在原始上下文對(duì)象內(nèi)部能夠相互替換,本文就將通過代碼示例給大家詳細(xì)的介紹一下Go的策略模式,需要的朋友可以參考下
    2023-08-08
  • go實(shí)現(xiàn)thrift的網(wǎng)絡(luò)傳輸性能及需要注意問題示例解析

    go實(shí)現(xiàn)thrift的網(wǎng)絡(luò)傳輸性能及需要注意問題示例解析

    這篇文章主要為大家介紹了go實(shí)現(xiàn)thrift的網(wǎng)絡(luò)傳輸性能及需要注意問題示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • 一文幫你搞懂Go面試中常問的channel問題

    一文幫你搞懂Go面試中常問的channel問題

    channel是Golang面試時(shí)經(jīng)常會(huì)問到的問題,所以這篇文章為大家整理了channel??嫉囊恍﹩栴}以及回答,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-06-06
  • Golang微服務(wù)框架Kratos實(shí)現(xiàn)分布式任務(wù)隊(duì)列Asynq的方法詳解

    Golang微服務(wù)框架Kratos實(shí)現(xiàn)分布式任務(wù)隊(duì)列Asynq的方法詳解

    任務(wù)隊(duì)列(Task Queue) 一般用于跨線程或跨計(jì)算機(jī)分配工作的一種機(jī)制,在Golang語言里面,我們有像Asynq和Machinery這樣的類似于Celery的分布式任務(wù)隊(duì)列,本文就給大家詳細(xì)介紹一下Golang微服務(wù)框架Kratos實(shí)現(xiàn)分布式任務(wù)隊(duì)列Asynq的方法,需要的朋友可以參考下
    2023-09-09
  • Golang 按行讀取文件的三種方法小結(jié)

    Golang 按行讀取文件的三種方法小結(jié)

    本文主要介紹了Golang 按行讀取文件的三種方法小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Golang實(shí)踐之Error創(chuàng)建和處理詳解

    Golang實(shí)踐之Error創(chuàng)建和處理詳解

    在 C#、Java 等語言中常常使用 try...catch的方式來捕獲異常,但是在Golang 對(duì)于錯(cuò)誤處理有不同的方式,像網(wǎng)上也有很多對(duì) error 處理的最佳實(shí)踐的文章,其中很多其實(shí)就是對(duì) error 的統(tǒng)一封裝,使用規(guī)范進(jìn)行約束,本文主要是記錄自己對(duì)處理 Error 的一些認(rèn)識(shí)和學(xué)習(xí)
    2023-09-09

最新評(píng)論