日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

golang xorm及time.Time自定義解決json日期格式的問題

瀏覽:185日期:2024-05-30 11:49:53

golang默認的time.Time類型在轉為json格式時不是常用的2019-05-08 10:00:01這種格式,解決辦法是自定義一個時間類型,例如

type myTime time.Time ,然后針對myTime實現Marshaler接口的MarshalJSON方法,例如:

package models import ( 'database/sql/driver' 'time') const localDateTimeFormat string = '2006-01-02 15:04:05' type LocalTime time.Time func (l LocalTime) MarshalJSON() ([]byte, error) { b := make([]byte, 0, len(localDateTimeFormat)+2) b = append(b, ’'’) b = time.Time(l).AppendFormat(b, localDateTimeFormat) b = append(b, ’'’) return b, nil} func (l *LocalTime) UnmarshalJSON(b []byte) error { now, err := time.ParseInLocation(`'`+localDateTimeFormat+`'`, string(b), time.Local) *l = LocalTime(now) return err}

上面的代碼在網上隨手一搜就能找到,沒有什么困難的,接下來的才是本篇文章的重點,這玩意結合xorm使用時,特別是字段類型為*LocalTime的時候才需要折騰一番。

下面是我的對應數據庫表結構的struct 定義,

type ServerInfo struct { ServerInfoId string `xorm:'varchar(32) pk server_info_id'` CreatedAtLocalTime `xorm:'timestamp created'` UpdatedAtLocalTime `xorm:'timestamp updated'` DeletedAt*LocalTime `xorm:'timestamp deleted index'` OrgId string `xorm:'varchar(100) org_id' json:'orgId'` ServerIp string `xorm:'varchar(128) server_ip' json:'serverIp'` ServerNameDesc string `xorm:'varchar(500) server_name_desc' json:'serverNameDesc'`ServerTimeNow LocalTime `xorm:'timestamp server_time' json:'serverTime'` DataReceiveTime LocalTime `xorm:'timestamp data_receive_time' sql:'DEFAULT:current_timestamp' json:'dataRecvTime'` LastUploadDataTime *LocalTime `xorm:'timestamp last_upload_data_time' json:'lastUploadDataTime'` LastCheckTime *LocalTime `xorm:'timestamp last_check_time' json:'lastCheckTime'` LastErrorTime *LocalTime `xorm:'timestamp last_error_time' json:'lastErrorTime'` }

注意上面的字段類型,既有LocalTime類型的,又有*LocalTime類型的,*LocalTime是考慮到有時候數據值可能為NULL,即字段值可能為空的情況。

xorm不知道如何為LocalTime這個自定義類型進行賦值或者取值,因此需要實現xorm的core包中的Conversion接口,這個接口的定義如下:

golang xorm及time.Time自定義解決json日期格式的問題

注意,坑已經隱藏在上面的接口定義中了,過一會說。

整個完整的自定義時間類型的代碼變成了下面的這樣:

package models import ( 'database/sql/driver' 'time') const localDateTimeFormat string = '2006-01-02 15:04:05' type LocalTime time.Time func (l LocalTime) MarshalJSON() ([]byte, error) { b := make([]byte, 0, len(localDateTimeFormat)+2) b = append(b, ’'’) b = time.Time(l).AppendFormat(b, localDateTimeFormat) b = append(b, ’'’) return b, nil} func (l *LocalTime) UnmarshalJSON(b []byte) error { now, err := time.ParseInLocation(`'`+localDateTimeFormat+`'`, string(b), time.Local) *l = LocalTime(now) return err} func (l LocalTime) String() string { return time.Time(l).Format(localDateTimeFormat)} func (l LocalTime)Now()(LocalTime){ return LocalTime(time.Now())} func (l LocalTime)ParseTime(t time.Time)(LocalTime){ return LocalTime(t)} func (j LocalTime) format() string { return time.Time(j).Format(localDateTimeFormat)} func (j LocalTime) MarshalText() ([]byte, error) { return []byte(j.format()), nil} func (l *LocalTime) FromDB(b []byte) error { if nil == b || len(b) == 0 { l = nil return nil } var now time.Time var err error now, err = time.ParseInLocation(localDateTimeFormat, string(b), time.Local) if nil == err { *l = LocalTime(now) return nil } now, err = time.ParseInLocation('2006-01-02T15:04:05Z', string(b), time.Local) if nil == err { *l = LocalTime(now) return nil } panic('自己定義個layout日期格式處理一下數據庫里面的日期型數據解析!') return err} //func (t *LocalTime) Scan(v interface{}) error {// // Should be more strictly to check this type.// vt, err := time.Parse('2006-01-02 15:04:05', string(v.([]byte)))// if err != nil {// return err// }// *t = LocalTime(vt)// return nil//} func (l *LocalTime) ToDB() ([]byte, error) { if nil == l { return nil,nil } return []byte(time.Time(*l).Format(localDateTimeFormat)), nil} func (l *LocalTime) Value() (driver.Value, error) { if nil==l { return nil, nil } return time.Time(*l).Format(localDateTimeFormat), nil}

此時,要是數據庫的字段內容都有值的話插入和更新應該是沒有什么問題,但是*LocalTime字段的值為nil的話問題就開始出現了,上面說了,ToDB()方法的返回值類型為[]byte,當字段值為nil時,返回nil看上去一切正常,但是xorm打印出來的sql語句數據值是下面這個樣子的:

golang xorm及time.Time自定義解決json日期格式的問題

這個[]uint8(nil)就是*LocalTime值為nil時的情況,數據庫驅動是不認可[]uint8(nil)這種數據去寫給timestamp類型字段的,問題的根源就是ToDB方法的返回值類型為[]byte,既然是這樣,就需要我們人為的把[]uint8(nil)這種類型改為interface(nil)類型,數據庫驅動會識別interface(nil)為NULL值,修改代碼xormstatement.go第322行,把原來的val=data改成下面的樣子:

golang xorm及time.Time自定義解決json日期格式的問題

就是把val=data改為 if nil==data { val=nil } else {val=data} ,看上去邏輯沒有什么變化,但是給val=nil賦值的時候,val的類型就從[]uint8(nil)變成了interface(nil)了,這樣數據庫驅動就可以正確處理空值了。

除了需要修改xormstatement.go文件的內容,還需要修改xormsession_convert.go的第558行,增加以下代碼:

golang xorm及time.Time自定義解決json日期格式的問題

主要是增加下面的代碼

//fix when pointer type value is null,added by peihexian,2019-05-07if nil==data { return nil,nil}

之所以加這個代碼是因為xorm作者沒有考慮指針類型字段值為nil的情況,xorm對有轉換的字段要么當成數字,要么當成了字符串,這兩種對于NULL類型的值都不適用,所以需要增加if nil==data return nil,nil這樣的代碼,還是把數據值組織成interface(nil)去給數據庫驅動去處理。

另外還有一個地方,是session_convert.go 第556行,同樣需要增加

if nil==data { //edit by peihexian 2019.06.19 return nil,nil}

下面是加完以后的樣子

golang xorm及time.Time自定義解決json日期格式的問題

到這里,對xorm做了幾處小的修改,自定義日期的問題及json格式化問題完美解決。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品久久免费| 麻豆中文一区二区| 国产+成+人+亚洲欧洲在线| 欧美日一区二区三区在线观看国产免| 婷婷亚洲五月| 黑森林国产精品av| 国产日产精品_国产精品毛片| 美女国产精品久久久| 欧美日韩亚洲一区二区三区在线| 青青国产精品| 国产欧美日韩免费观看| 国产精品一区二区精品| 亚洲天堂av影院| 久久av在线| 日韩1区2区日韩1区2区| 国产欧美日韩亚洲一区二区三区| 黑森林国产精品av| 欧美男人天堂| 亚洲精品午夜av福利久久蜜桃| 亚洲国产一区二区三区在线播放| 91精品国产91久久久久久黑人| 久久精品高清| 91九色精品| 国产日产高清欧美一区二区三区| 欧美中文字幕一区二区| 亚洲欧美成人综合| 国产精品tv| 日韩午夜av| 欧美aa在线视频| 香蕉久久99| 国产亚洲欧美日韩精品一区二区三区| 亚洲1234区| 蜜桃传媒麻豆第一区在线观看| 国产盗摄——sm在线视频| 亚洲在线观看| 久久精品超碰| 亚洲国产影院| 欧美日韩调教| 欧美日韩国产传媒| 久久不卡日韩美女| 欧美女激情福利| 欧美激情麻豆| 日韩欧美三区| 国产综合视频| 日本不卡免费高清视频在线| 日本免费在线视频不卡一不卡二| 精品91久久久久| 久久99久久人婷婷精品综合| 影音先锋久久| 国产一区二区三区日韩精品| 麻豆9191精品国产| 亚洲伦乱视频| 精品一区91| 欧美a在线观看| 日本h片久久| 日韩一区网站| 日韩专区欧美专区| 在线午夜精品| 亚洲欧美日韩一区在线观看| 欧美日韩水蜜桃| 亚洲最新无码中文字幕久久| 国产一区福利| 日韩精品一区二区三区免费观影| 婷婷激情一区| 精品国产91| 国产精品草草| 色婷婷综合网| 精品国产成人| 91亚洲成人| av一区二区高清| 国产婷婷精品| 亚洲日本在线观看视频| 欧美午夜三级| 精品欠久久久中文字幕加勒比| 精品国产欧美日韩| 国产91在线精品| 欧美日韩在线网站| 视频一区视频二区中文字幕| 亚洲深夜福利| 国产伦一区二区三区| 国产精品v日韩精品v欧美精品网站| 中文av在线全新| 激情久久久久久| 日本中文字幕一区二区视频| 国产精品白丝一区二区三区| 国产精品亚洲四区在线观看| 青青草精品视频| 精品久久一区| 性色av一区二区怡红| 欧美影院精品| 99久久久久国产精品| 中文字幕av亚洲精品一部二部| 91亚洲人成网污www| 九一国产精品| 国产精品免费不| 欧美一级精品| 日韩av中文字幕一区二区三区| 激情欧美一区二区三区| 首页国产欧美久久| а√天堂中文在线资源8| 久久亚洲色图| 亚洲精品在线影院| 欧美一区影院| 欧美一级专区| 激情婷婷综合| 吉吉日韩欧美| 国产精品巨作av| 亚洲一区二区三区四区电影| 日韩欧美自拍| 国内一区二区三区| 亚洲免费福利一区| 婷婷亚洲五月色综合| 国内自拍视频一区二区三区| 日本三级亚洲精品| 亚洲久久视频| 亚洲色图国产| 视频一区二区中文字幕| 一区久久精品| 亚洲高清成人| 美女亚洲一区| 丝袜美腿诱惑一区二区三区| 岛国av在线网站| 神马午夜在线视频| 国产精品黑丝在线播放| 久久亚洲道色| 国产精品115| 你懂的国产精品永久在线| 欧美一区=区三区| 国产欧美日韩精品一区二区免费| 精品久久视频| 欧美国产极品| 日本不卡不码高清免费观看| 美女国产一区| 日产欧产美韩系列久久99| 亚洲我射av| 69精品国产久热在线观看| 欧美在线黄色| 精品国内亚洲2022精品成人| 精品国产精品国产偷麻豆 | 亚洲日本免费电影| 视频在线观看一区| 亚洲精品美女| 美女尤物国产一区| 免费看av不卡| 99xxxx成人网| 欧美日韩中出| 久久婷婷丁香| 蜜桃视频第一区免费观看| 欧美一区自拍| 国产精品高颜值在线观看| 亚洲国产成人精品女人| 日本h片久久| 97se综合| 久久国产精品久久w女人spa| 一区二区亚洲视频| 欧美激情精品| 噜噜噜躁狠狠躁狠狠精品视频| 国产精品久久亚洲不卡| 日韩黄色大片| 亚洲深夜影院| 老牛国内精品亚洲成av人片 | 美腿丝袜在线亚洲一区| 天堂8中文在线最新版在线| 久久福利一区| 免费一区二区三区在线视频| 中文一区一区三区高中清不卡免费| 亚洲精品中文字幕99999| 久久久久久久欧美精品| 亚洲香蕉网站| 国产精品jk白丝蜜臀av小说| 久久久国产亚洲精品| 欧美一区=区三区| 女同性一区二区三区人了人一| 亚洲精品在线影院| 亚洲欧美一级| 人人香蕉久久| 麻豆成人av在线| 日本91福利区| 黄色亚洲免费| 电影亚洲精品噜噜在线观看| 国产精品手机在线播放| 亚洲欧美综合| 久久男女视频| 92国产精品| 美女视频黄久久| 日韩av成人高清| 免费不卡在线观看| 亚洲大全视频| 亚洲二区三区不卡| 亚洲成人免费| 免费视频国产一区| 香蕉人人精品| 国产视频一区三区| 精品1区2区3区4区| 国产国产精品| 国产精品普通话对白| 午夜在线精品| 免费在线看一区| 日韩高清一区在线| 日本亚洲欧美天堂免费|