校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > golang xorm及time.Time自定義解決json日期格式的問題

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

熱門標簽:地圖標注免費定制店 宿遷便宜外呼系統代理商 不封卡外呼系統 仙桃400電話辦理 上海極信防封電銷卡價格 鄭州智能語音電銷機器人價格 湛江crm外呼系統排名 重慶慶云企業400電話到哪申請 寧波語音外呼系統公司

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"`
 CreatedAt        LocalTime `xorm:"timestamp created"`
 UpdatedAt        LocalTime `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接口,這個接口的定義如下:

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

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

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語句數據值是下面這個樣子的:

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

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

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

主要是增加下面的代碼

//fix when pointer type value is null,added by peihexian,2019-05-07
if 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
}

下面是加完以后的樣子

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

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

您可能感興趣的文章:
  • golang 定時任務方面time.Sleep和time.Tick的優劣對比分析
  • 解決Golang time.Parse和time.Format的時區問題
  • 解決golang時間字符串轉time.Time的坑
  • golang的時區和神奇的time.Parse的使用方法
  • 對Golang中的runtime.Caller使用說明
  • Golang中的time.Duration類型用法說明
  • golang time包做時間轉換操作
  • golang time常用方法詳解

標簽:電子產品 西雙版納 物業服務 青海 遼寧 安康 儋州 海南

巨人網絡通訊聲明:本文標題《golang xorm及time.Time自定義解決json日期格式的問題》,本文關鍵詞  golang,xorm,及,time.Time,自定義,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang xorm及time.Time自定義解決json日期格式的問題》相關的同類信息!
  • 本頁收集關于golang xorm及time.Time自定義解決json日期格式的問題的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    99久免费精品视频在线观看| 午夜精品爽啪视频| 国产精品资源站在线| 欧美精品 国产精品| 日本亚洲免费观看| 日韩视频免费观看高清在线视频| 麻豆一区二区三| 久久久久久久久久久久久久久99 | 精品国产伦一区二区三区免费| 日韩电影在线观看网站| 日韩美女主播在线视频一区二区三区 | 欧美成人a在线| 国产剧情一区在线| 国产精品电影院| 欧美午夜精品理论片a级按摩| 亚洲成人1区2区| 日韩一级免费观看| 国产精品综合久久| 亚洲视频香蕉人妖| 欧美一区二区三区成人| 国产在线视频精品一区| 最新国产精品久久精品| 欧美日韩激情一区二区| 激情图片小说一区| 亚洲丝袜美腿综合| 日韩欧美激情一区| 成人av动漫网站| 日本中文在线一区| 中文字幕佐山爱一区二区免费| 成人污视频在线观看| 欧美福利电影网| 亚洲人成精品久久久久| 国产成人免费视频网站高清观看视频| 国产成人在线视频播放| 91精品福利在线一区二区三区 | 91精品国产入口在线| 91精品国产美女浴室洗澡无遮挡| 欧美高清视频在线高清观看mv色露露十八 | 亚洲日本护士毛茸茸| 欧美视频一区二区三区四区 | 精品国产麻豆免费人成网站| 成人禁用看黄a在线| 亚洲444eee在线观看| 精品欧美久久久| 成人久久18免费网站麻豆| 一区二区三区 在线观看视频| 欧美一级黄色大片| 成人久久18免费网站麻豆| 亚洲综合清纯丝袜自拍| 91精品在线观看入口| 成人免费电影视频| 免费欧美日韩国产三级电影| 中文字幕av一区 二区| 欧美乱熟臀69xxxxxx| 国产黑丝在线一区二区三区| 一区二区高清视频在线观看| 精品精品国产高清一毛片一天堂| 91在线无精精品入口| 久久精品国产亚洲高清剧情介绍| 国产精品毛片a∨一区二区三区 | www激情久久| 一区二区三区在线视频免费| va亚洲va日韩不卡在线观看| 精品国产露脸精彩对白| 久久国产乱子精品免费女| 亚洲天堂网中文字| 自拍偷拍欧美激情| 日韩不卡免费视频| 综合色天天鬼久久鬼色| 91九色最新地址| 国内精品免费**视频| 国产欧美日韩另类视频免费观看 | 久久精品999| 日韩高清在线观看| 欧美日韩色综合| 亚洲精品成人少妇| 欧美疯狂做受xxxx富婆| 亚洲免费av观看| 91玉足脚交白嫩脚丫在线播放| 亚洲婷婷在线视频| 99国产精品视频免费观看| 亚洲国产乱码最新视频| 91 com成人网| 国产成a人亚洲精品| 日韩精品一区第一页| 自拍偷拍亚洲综合| 自拍偷自拍亚洲精品播放| 亚洲另类在线制服丝袜| 中文字幕亚洲综合久久菠萝蜜| 亚洲成人激情综合网| 欧美撒尿777hd撒尿| 91免费看视频| 成人午夜大片免费观看| 国产成人精品影视| 国产一区欧美日韩| 久久精品av麻豆的观看方式| 天堂成人国产精品一区| 欧美tk—视频vk| 日韩无一区二区| av成人免费在线观看| 久久精品国产久精国产| 亚洲精品中文在线| 26uuu久久天堂性欧美| 欧美日韩精品一区二区三区蜜桃| 午夜精品福利一区二区蜜股av| 国产精品久久久久久久久免费丝袜| 日韩一区二区三区视频| 国产日本欧美一区二区| 久久精品视频网| 久久不见久久见免费视频7| 国产亚洲综合在线| 久久精品水蜜桃av综合天堂| 欧美韩国一区二区| 亚洲人成小说网站色在线| 国产精品乱子久久久久| 亚洲欧洲av在线| 亚洲一区二区三区视频在线播放 | 国产精品美女一区二区在线观看| 日韩欧美一级在线播放| 国产精品国产三级国产a| 亚洲国产一区二区三区青草影视| 色综合天天狠狠| 在线观看一区二区精品视频| 99精品国产91久久久久久| 精品一二三四区| 欧美日韩一区二区三区在线看| 91成人免费电影| 日日骚欧美日韩| 欧美电视剧在线看免费| 久久66热偷产精品| 久久久久久久免费视频了| 亚洲欧美二区三区| 精品亚洲成a人| 国产欧美视频一区二区| 91影视在线播放| 日韩精品一二三区| 国产精品情趣视频| 欧美视频在线一区二区三区| 日韩成人免费在线| www日韩大片| 色激情天天射综合网| 久久伊99综合婷婷久久伊| 裸体一区二区三区| 日韩精品一区二区三区蜜臀| 日韩中文字幕麻豆| 色综合视频在线观看| 国产喷白浆一区二区三区| 亚洲一区在线观看视频| 久久99精品国产| av色综合久久天堂av综合| 成人网页在线观看| 国产精品免费视频观看| 日韩和欧美一区二区三区| 欧洲av在线精品| 亚洲日穴在线视频| 欧美日韩视频一区二区| 久久99久久久欧美国产| 欧美精品一区二区三区在线| 国产精品白丝jk白祙喷水网站| 中文字幕在线不卡一区| 色综合久久久久| 免费在线看一区| 国产精品国产三级国产aⅴ原创| 成人激情免费视频| **欧美大码日韩| 日韩欧美激情一区| 色狠狠色噜噜噜综合网| 国产揄拍国内精品对白| 国产精品美日韩| 欧美日韩中文精品| av成人免费在线观看| 精品在线一区二区三区| 亚洲一二三四在线| 国产精品国产三级国产三级人妇 | 国产日韩av一区| 精品亚洲porn| 亚洲人成精品久久久久| 久久久久99精品一区| 国产免费观看久久| 国产亚洲综合av| 久久免费偷拍视频| 91精品欧美久久久久久动漫| 国精品**一区二区三区在线蜜桃| 一区二区中文视频| 欧美成人欧美edvon| 7777精品伊人久久久大香线蕉 | 激情综合色综合久久综合| 午夜精品久久久久久久久| 婷婷丁香激情综合| 国产综合色在线视频区| 国产毛片精品国产一区二区三区| 国产伦精一区二区三区| 国产丶欧美丶日本不卡视频| 高清国产一区二区三区| 丁香婷婷综合色啪| 欧美精品乱人伦久久久久久| 亚洲精品一区二区在线观看| 中文字幕乱码亚洲精品一区| 洋洋成人永久网站入口| 精品亚洲成a人|