Go語(yǔ)言中使用gorm小結(jié)
首先說(shuō)明的是,在項(xiàng)目中使用orm的好處很多:
- 防止直接拼接sql語(yǔ)句引入sql注入漏洞
- 方便對(duì)modle進(jìn)行統(tǒng)一管理
- 專(zhuān)注業(yè)務(wù),加速開(kāi)發(fā)
壞處也是顯而易見(jiàn)的:
- 開(kāi)發(fā)者與最終的sql語(yǔ)句隔了一層orm,因此可能會(huì)不慎引入爛sql
- 依賴(lài)于orm的成熟度,無(wú)法進(jìn)行一些「復(fù)雜」的查詢(xún)。當(dāng)然,復(fù)雜的查詢(xún)一大半都是應(yīng)該從設(shè)計(jì)上規(guī)避的
留意不合法的時(shí)間值
MySQL的DATE/DATATIME類(lèi)型可以對(duì)應(yīng)Golang的time.Time。但是,如果DATE/DATATIME不慎插入了一個(gè)無(wú)效值,例如2016-00-00 00:00:00, 那么這條記錄是無(wú)法查詢(xún)出來(lái)的。會(huì)返回gorm.RecordNotFound類(lèi)型錯(cuò)誤。零值0000-00-00 00:00:00是有效值,不影響正常查詢(xún)。
留意tagsql:"default:null"
gorm對(duì)各種tag的支持非常完善。但是有些行為跟直覺(jué)不太一致,需要注意。當(dāng)對(duì)某字段設(shè)置tagsql:"default:null"時(shí),你想通過(guò)update設(shè)置該字段為null就不可能了,只能通過(guò)raw sql。這是gorm設(shè)計(jì)的取向問(wèn)題。
如何通過(guò)gorm設(shè)置字段為null值
字段允許為null值肯定是設(shè)計(jì)存在問(wèn)題。但是,往往前人埋下的坑需要你去填。gorm作者給出了兩種方法,以string為例:
在golang中,聲明該字段為*string
使用sql.NullString類(lèi)型
推薦使用后者。
留意連接串中的loc
例如通過(guò)如下連接串打開(kāi)mysql連接:
db, err := gorm.Open("mysql", "db:dbadmin@tcp(127.0.0.1:3306)/foo?charset=utf8&parseTime=true&loc=Local")
parseTime=true&loc=Local說(shuō)明會(huì)解析時(shí)間,時(shí)區(qū)是機(jī)器的local時(shí)區(qū)。機(jī)器之間的時(shí)區(qū)可能不一致會(huì)設(shè)置有問(wèn)題,這導(dǎo)致從相同庫(kù)的不同實(shí)例查詢(xún)出來(lái)的結(jié)果可能解析以后就不一樣。因此推薦將loc統(tǒng)一設(shè)置為一個(gè)時(shí)區(qū),如parseTime=true&loc=America%2FChicago
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
相關(guān)文章
golang獲取客戶(hù)端ip的實(shí)現(xiàn)
本文主要介紹了golang獲取客戶(hù)端ip的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
解決Go語(yǔ)言中高頻次和高并發(fā)下隨機(jī)數(shù)重復(fù)的問(wèn)題
在Golang中,獲取隨機(jī)數(shù)的方法一般會(huì)介紹有兩種,一種是基于math/rand的偽隨機(jī),一種是基于crypto/rand的真隨機(jī),math/rand由于其偽隨機(jī)的原理,經(jīng)常會(huì)出現(xiàn)重復(fù)的隨機(jī)數(shù),導(dǎo)致在需要進(jìn)行隨機(jī)的業(yè)務(wù)出現(xiàn)較多的重復(fù)問(wèn)題,所以本文給大家介紹了較好的解放方案2023-12-12
windows下使用vscode搭建golang環(huán)境并調(diào)試的過(guò)程
這篇文章主要介紹了在windows下使用vscode搭建golang環(huán)境并進(jìn)行調(diào)試,主要包括安裝方法及環(huán)境變量配置技巧,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09
詳解為什么說(shuō)Golang中的字符串類(lèi)型不能修改
在接觸Go這么語(yǔ)言,可能你經(jīng)常會(huì)聽(tīng)到這樣一句話。對(duì)于字符串不能修改,可能你很納悶,日常開(kāi)發(fā)中我們對(duì)字符串進(jìn)行修改也是很正常的,為什么又說(shuō)Go中的字符串不能進(jìn)行修改呢?本文就來(lái)通過(guò)實(shí)際案例給大家演示一下2023-03-03

