亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 在golang xorm中使用postgresql的json,array類型的操作

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

熱門標簽:壽光微信地圖標注 excel地圖標注分布數據 阿克蘇地圖標注 外呼系統顯本地手機號 外呼系統用什么卡 百度地圖標注后傳給手機 涿州代理外呼系統 電話機器人軟件免費 評價高的400電話辦理

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

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

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

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

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

type Int64Array []int64

func (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 []string
	var intarr []int64

	err := 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 = intarr
	return nil
}

func serializeBigIntArray(s []int64, prefix string, suffix string) []byte {
	var buffer bytes.Buffer

	buffer.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.Buffer

	buffer.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"`
	Status        int16             `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)要注意如下現象,

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

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

那么當我們使用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中返回的名字"`
}

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

您可能感興趣的文章:
  • golang xorm及time.Time自定義解決json日期格式的問題
  • golang xorm日志寫入文件中的操作
  • go語言 xorm框架 postgresql 的用法及詳細注解
  • golang中xorm的基本使用說明
  • 解決goxorm無法更新值為默認值的問題
  • xorm根據數據庫生成go model文件的操作
  • 使用go xorm來操作mysql的方法實例
  • go xorm框架的使用

標簽:欽州 吐魯番 汕頭 銅川 雞西 重慶 梅河口 蘭州

巨人網絡通訊聲明:本文標題《在golang xorm中使用postgresql的json,array類型的操作》,本文關鍵詞  在,golang,xorm,中,使用,postgresql,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《在golang xorm中使用postgresql的json,array類型的操作》相關的同類信息!
  • 本頁收集關于在golang xorm中使用postgresql的json,array類型的操作的相關信息資訊供網民參考!
  • 推薦文章
    日韩中文字幕一区| 国产一区二区福利久久| 麻豆系列国产剧在线观看| 美国一区二区三区| 韩国三级香港三级日本三级la| 国产伦精品一区二区三区无广告 | 亚洲第一页乱| 免费的黄视频| 久久99中文字幕| 欧美日本免费| 四虎精品在线观看| 精品国产一区二区三区国产馆| 日本免费乱理伦片在线观看2018| 中文字幕一区二区三区精彩视频 | 亚州视频一区二区| 国产网站免费观看| 91麻豆国产| 日韩专区第一页| 国产极品白嫩美女在线观看看| 色综合久久天天综线观看| 久久精品道一区二区三区| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 成人a大片在线观看| 欧美爱色| 黄视频网站在线看| 欧美激情在线精品video| 久久国产影院| 国产福利免费视频| 免费毛片播放| 欧美a免费| 色综合久久天天综合| 亚欧视频在线| 91麻豆爱豆果冻天美星空| 二级片在线观看| 麻豆系列国产剧在线观看| 亚洲第一色在线| 超级乱淫黄漫画免费| 四虎精品在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 免费国产一级特黄aa大片在线| 精品美女| 国产91视频网| 九九干| a级毛片免费全部播放| 日韩专区在线播放| 亚洲女人国产香蕉久久精品| 日韩在线观看视频黄| 久久国产一区二区| 黄视频网站在线看| 国产伦精品一区三区视频| 亚州视频一区二区| 日本伦理片网站| 国产伦理精品| 日本特黄特色aaa大片免费| 免费的黄视频| a级毛片免费观看网站| 久久国产一久久高清| 精品久久久久久免费影院| 久久精品免视看国产明星| 91麻豆精品国产高清在线| 亚洲天堂免费| 午夜家庭影院| 日韩在线观看免费| 欧美大片a一级毛片视频| 日韩欧美一及在线播放| 日韩在线观看视频免费| 日本特黄特色aa大片免费| 欧美激情一区二区三区在线| 久草免费在线色站| 日韩专区第一页| 国产a视频精品免费观看| 成人免费网站久久久| 天天做日日爱| 国产国语对白一级毛片| 日韩综合| 青青久在线视频| 香蕉视频三级| 国产国语对白一级毛片| 亚久久伊人精品青青草原2020| 你懂的国产精品| 你懂的在线观看视频| 国产一区免费在线观看| 国产一区二区福利久久| 亚洲天堂一区二区三区四区| 国产网站免费观看| 日韩在线观看视频黄| 精品国产香蕉伊思人在线又爽又黄| 在线观看成人网| 国产网站免费| 国产精品自拍在线观看| 午夜欧美福利| a级精品九九九大片免费看| 四虎影视库国产精品一区| 成人在免费观看视频国产| 日韩一级黄色| 欧美大片aaaa一级毛片| 天天做人人爱夜夜爽2020毛片| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 亚洲精品久久玖玖玖玖| 午夜久久网| 成人av在线播放| 精品久久久久久免费影院| 四虎影视久久| 日韩男人天堂| 精品视频一区二区| 天天色成人| 久久国产精品自线拍免费| 免费一级片在线观看| 日本免费乱人伦在线观看| 韩国三级一区| 中文字幕Aⅴ资源网| 精品国产香蕉伊思人在线又爽又黄| 久久精品人人做人人爽97| 九九精品在线| 欧美大片一区| 久久成人亚洲| 日韩欧美一二三区| 免费国产在线观看不卡| 午夜激情视频在线播放| 国产精品自拍在线| 欧美大片a一级毛片视频| 青青久久精品| 精品视频在线观看一区二区三区| 日韩一级黄色| 黄视频网站在线看| 日韩免费片| 超级乱淫伦动漫| 九九精品在线| 精品视频在线看| 黄视频网站免费观看| 99久久精品国产高清一区二区| 国产91精品露脸国语对白| 精品国产亚洲一区二区三区| 国产麻豆精品免费密入口| 亚洲www美色| a级毛片免费观看网站| 麻豆网站在线免费观看| 久久成人综合网| 国产伦久视频免费观看 视频| 韩国三级香港三级日本三级la| 黄视频网站免费| 欧美激情一区二区三区视频| 九九精品在线| 成人免费网站久久久| 青青久久网| 亚洲精品久久久中文字| 国产视频一区在线| 国产网站麻豆精品视频| 欧美国产日韩一区二区三区| 999精品在线| 国产伦久视频免费观看 视频| 精品视频免费在线| 日韩专区一区| 亚洲 国产精品 日韩| 欧美激情一区二区三区在线 | 国产精品1024在线永久免费| 天天做日日爱夜夜爽| 天天做日日爱| 国产亚洲精品成人a在线| 国产麻豆精品免费密入口| 成人免费网站视频ww| 久久精品大片| 国产麻豆精品免费视频| 韩国三级一区| 免费毛片播放| 91麻豆精品国产高清在线| 日日日夜夜操| 精品国产亚一区二区三区| 毛片高清| 欧美18性精品| 青青久在线视频| 国产a毛片| 国产不卡在线播放| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产伦久视频免费观看 视频| 国产伦久视频免费观看 视频| 欧美一级视频免费观看| 香蕉视频一级| 国产麻豆精品高清在线播放| 欧美一级视频免费| 午夜欧美成人久久久久久| 亚洲第一色在线| 黄视频网站在线看| 国产视频久久久| 精品国产亚洲人成在线| 国产美女在线一区二区三区| 九九九网站| 黄色福利| 你懂的国产精品| 日韩专区一区| 国产欧美精品午夜在线播放| 91麻豆爱豆果冻天美星空| 国产视频在线免费观看| 亚洲女初尝黑人巨高清在线观看| 四虎久久影院| 免费一级片在线观看| 国产网站免费视频| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 久草免费在线视频| 日本伦理片网站|