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

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

在golang xorm中使用postgresql的json,array類型的操作

瀏覽:269日期:2024-05-29 15:59:40

xorm支持各種關系數據庫,最近使用postgresql時,總是踩到一些坑,在此記錄下解決方式。

在使用postgresql的array類型時,查詢有點問題,xorm的官方文檔給出重寫的方式,但是不是很清晰:

官方文檔鏈接:http://xorm.io/docs

在golang xorm中使用postgresql的json,array類型的操作

也就是說碰到基礎庫不支持的類型,需要我們去重寫ToDB、FromDB方法,廢話不多說直接上代碼:

比如int8[]類型,自定一個Int64Array

type Int64Array []int64func (s *Int64Array) FromDB(bts []byte) error {if len(bts) == 0 {return nil}str := string(bts)if strings.HasPrefix(str, '{') {str = '[' + str[1:len(str)]}if strings.HasSuffix(str, '}') {str = str[0: len(str)-1] + ']'}var ia = &[]int64{}err := json.Unmarshal([]byte(str), ia)if err != nil {return err}*s = Int64Array(*ia)return nil}func (s *Int64Array) ToDB() ([]byte, error) {return serializeBigIntArray(*s, '{', '}'), nil}func (arr Int64Array) MarshalJSON() ([]byte, error) {return serializeBigIntArrayAsString(arr, '[', ']'), nil}func (arr *Int64Array) UnmarshalJSON(b []byte) error {var strarr []stringvar intarr []int64err := json.Unmarshal(b, &strarr)if err != nil {return err}for _, s := range strarr {i, err := strconv.ParseInt(s, 10, 64)if err != nil {return err}intarr = append(intarr, i)}*arr = intarrreturn nil}func serializeBigIntArray(s []int64, prefix string, suffix string) []byte {var buffer bytes.Bufferbuffer.WriteString(prefix)for idx, val := range s {if idx > 0 {buffer.WriteString(',')}buffer.WriteString(strconv.FormatInt(val, 10))}buffer.WriteString(suffix)return buffer.Bytes()}func serializeBigIntArrayAsString(s []int64, prefix string, suffix string) []byte {var buffer bytes.Bufferbuffer.WriteString(prefix)for idx, val := range s {if idx > 0 {buffer.WriteString(',')}buffer.WriteString(''')buffer.WriteString(strconv.FormatInt(val, 10))buffer.WriteString(''')}buffer.WriteString(suffix)return buffer.Bytes()}json類型:

type Cover struct { Id int64 `json:'id,omitempty'` Fid string `json:'fid,omitempty'` Type int8 `json:'type,omitempty'` Url string `json:'url,omitempty'`}func (c *Cover) FromDB(bytes []byte) error { return json.Unmarshal(bytes, c)}func (c *Cover) ToDB() (bytes []byte, err error) { bytes, err = json.Marshal(c) return}具體使用:

type Course struct {Id int64 `json:'id,string' form:'id'`Name string `json:'name' form:'name'`Brief string `json:'brief' form:'brief'`Description string `json:'description' form:'description'`Cover common.Cover `xorm:'Text' json:'cover' form:'cover'`Categories common.Int64Array `xorm:'Text' json:'categories' form:'categories[]'`Tags common.Int64Array `json:'tags' form:'tags[]'`Difficulty float64 `json:'difficulty' form:'difficulty'`Price float64 `json:'price' form:'price'`Markets common.Int64Array `json:'markets' form:'markets[]'`StudentAmount int64 `json:'studentAmount' form:'studentAmount'`SubjectAmount int64 `json:'subjectAmount' form:'subjectAmount'`Crt time.Time `json:'crt'`Lut time.Time `json:'lut'`Statusint16 `json:'status' form:'status'`common.Page `xorm:'-'`}

補充:golang gin xorm注意事項

1. 無論是golang還是xorm中,在填寫j’son字段時,注意空格,比如 `json:'abcd '` `json:'abcd'`是不一樣的,不仔細對比會出錯

2.當結合gin框中的

c.JSON(http.StatusOK,gin.H{})操作

并且使用xorm中的join,find操作時(https://www.kancloud.cn/xormplus/xorm/167102)要注意如下現象,

假如定義兩個結構體對應兩個表

在golang xorm中使用postgresql的json,array類型的操作

然后使用聯合查詢,先把兩個結構體結合成一個結構體,假如如下,在UserGroup中使用User和Group匿名結構體,

在golang xorm中使用postgresql的json,array類型的操作

那么當我們使用gin的c.JSON(http.StatusOK,gin.H{'data':UserGroup})返回數據時會導致Group和User中同名字段顯示不了,這應該是gin和xorm的不是很兼容造成的(沒有深究),

要解決這個問題,最好讓UserGroup中的User和Group不要以匿名結構體的形式存在

可以改成

type UserGroup struct { MyUser User `xorm:'extends' json:'你要json中返回的名字'` MyGroup Group `xorm:'extends' json:'你要json中返回的名字'`}

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

標簽: JavaScript
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久国产三级| 中文字幕一区二区精品区| 日韩精品久久理论片| 老司机精品久久| 国产一区久久| 亚洲精品一二三区区别| 九一成人免费视频| 国产真实久久| 一本色道久久精品| 丝袜亚洲另类欧美| 日本不卡不码高清免费观看| 日韩和欧美一区二区| 欧美一级一区| 国产精品22p| 精品国产精品国产偷麻豆| 久久精品国产在热久久| 老司机免费视频一区二区| 久久久免费人体| 国产不卡人人| 日韩精品欧美| 国产亚洲精品久久久久婷婷瑜伽| 亚洲婷婷丁香| 国产精品久久久久久久久久妞妞| 韩日一区二区| 久久一级电影| 免费成人在线影院| 国产美女久久| 久久久久久久欧美精品| 日韩不卡一区| 欧美精品一区二区久久| 蜜桃视频一区二区| 国产欧美久久一区二区三区| 国产不卡精品| 欧美女激情福利| 日韩高清不卡一区二区| 麻豆国产精品| 91久久久精品国产| 日本亚洲欧洲无免费码在线| 国产一区二区视频在线看| 免费久久久久久久久| 中文一区一区三区免费在线观 | 国产极品模特精品一二| 97国产成人高清在线观看| 999久久久精品国产| 日韩中文字幕不卡| 国产福利亚洲| 亚洲精品中文字幕乱码| 91在线成人| 亚洲成人国产| 欧美日韩亚洲一区二区三区在线| 日韩精品专区| 亚洲毛片在线免费| 国产一区二区三区探花| 美女黄网久久| 久久一区欧美| 亚洲视频电影在线| 97精品在线| 亚洲91在线| 中文在线中文资源| 亚洲不卡视频| 欧美性感美女一区二区| 国产精品色婷婷在线观看| 欧美中文字幕一区二区| 久久精品99国产精品| 国内激情久久| 国产精品3区| 午夜一级久久| 激情黄产视频在线免费观看| 亚洲久草在线| 精品欧美久久| 成人精品高清在线视频| 日精品一区二区三区| 久久精品导航| 美女久久久久久| 亚洲网址在线观看| 99精品综合| 久久精品国产亚洲一区二区三区| 中文字幕中文字幕精品| 久久亚洲成人| 国产成人精品免费视| 国产日韩欧美一区二区三区| 国产农村妇女精品一二区| 日韩精品中文字幕第1页| 国产美女视频一区二区| 蜜臀久久99精品久久久久宅男| 日本欧美不卡| 国产精成人品2018| 蜜桃久久久久久久| 亚洲婷婷在线| 日韩一区亚洲二区| 久久只有精品| 国产亚洲一区二区三区啪| 夜久久久久久| 另类中文字幕国产精品| 国产一区不卡| 欧美国产日韩电影| 日韩精品电影一区亚洲| 欧美女激情福利| 色88888久久久久久影院| 久久精品三级| 麻豆精品久久| 国产精品3区| 国产精品视频3p| 欧美日韩午夜| 国产私拍福利精品视频二区| 蜜臀久久久久久久| 午夜一级久久| 亚洲一区欧美二区| 婷婷综合在线| 亚洲成人精品| 国产99亚洲| 欧美日韩激情| 成人羞羞视频播放网站| 国产在线看片免费视频在线观看| 精品五月天堂| 国产精品成人自拍| 国产精品国码视频| 国产精久久久| 精品一区二区三区的国产在线观看| 国产亚洲高清在线观看| 欧美亚洲网站| 国产日产精品_国产精品毛片 | 成人综合一区| 国产一区二区三区四区五区传媒| 久久精品天堂| 精品亚洲a∨| 国产精品久久久久久久免费观看| 国产成人精品一区二区三区免费| 精品久久一区| 日韩av免费大片| 国产乱码午夜在线视频| 丝袜美腿诱惑一区二区三区| 在线日韩一区| 制服诱惑一区二区| 蜜臀久久99精品久久一区二区| 欧美 日韩 国产精品免费观看| 好看的亚洲午夜视频在线| 中文日韩欧美| 婷婷久久免费视频| 国产探花在线精品| 久久精品欧洲| 91精品一区国产高清在线gif | 亚洲欧美日本国产专区一区| 欧美激情91| 日韩中文在线电影| 日本不卡免费高清视频在线| 精品一区亚洲| 日韩精品久久理论片| 免费在线成人| 视频在线观看一区| aa亚洲婷婷| 欧美日韩亚洲一区二区三区在线| 一区三区视频| 国产精品igao视频网网址不卡日韩| 亚洲免费一区二区| 日韩一区二区三免费高清在线观看 | 偷拍精品精品一区二区三区| 精品99久久| 麻豆精品蜜桃| 夜夜嗨av一区二区三区网站四季av| 欧美综合二区| 亚州欧美在线| 精品一区二区男人吃奶 | 性色一区二区| 一区二区电影在线观看| 欧美片第1页| 国产成人久久精品一区二区三区| 日本亚洲最大的色成网站www| 99久久99久久精品国产片果冰| 国产美女撒尿一区二区| 日本va欧美va欧美va精品| 中文欧美日韩| 久久午夜精品| 色爱av综合网| 都市激情国产精品| 日本a口亚洲| 亚洲精品系列| 日韩一区二区三区精品视频第3页 日韩一区二区三区免费视频 | 在线天堂资源www在线污| 国产精品中文字幕亚洲欧美| 91tv亚洲精品香蕉国产一区| 亚洲精品黄色| 日韩国产欧美三级| 国产日韩视频在线| 国产盗摄——sm在线视频| 三级在线看中文字幕完整版| 久久香蕉网站| 免费精品视频| 国产日韩在线观看视频| 国产精品免费大片| 成人在线网站| 136国产福利精品导航网址| 国内亚洲精品| 国产精品亚洲一区二区三区在线观看| 91伊人久久| 国产情侣久久| 精品免费av一区二区三区| 亚洲欧美视频一区二区三区| 1024精品一区二区三区| 中文字幕在线官网|