婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 在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類型的操作的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产一区二区三区在线观看免费 | 亚洲福利一区二区三区| 国产精品无码永久免费888| 久久久久久电影| 国产亚洲欧美中文| 国产精品卡一卡二卡三| 中文字幕一区二区不卡| 亚洲精品视频自拍| 亚洲第一福利视频在线| 视频在线观看91| 老司机午夜精品99久久| 狠狠色丁香久久婷婷综| 国产一区二区在线电影| 不卡一区二区在线| 欧美体内she精视频| 欧美一区二区三区在线观看视频| 欧美一区二区观看视频| 国产片一区二区三区| 亚洲欧洲日本在线| 亚洲成人av一区二区三区| 六月丁香综合在线视频| 成人av免费网站| 欧美日韩视频第一区| 26uuu久久综合| 亚洲天堂a在线| 日本中文字幕一区二区视频| 国产高清精品网站| 在线观看一区二区视频| 日韩欧美不卡在线观看视频| 国产精品久久久久久妇女6080| 亚洲一区二区三区四区五区中文| 麻豆国产欧美一区二区三区| 99久久免费视频.com| 制服丝袜av成人在线看| 国产精品免费看片| 美女一区二区在线观看| 色拍拍在线精品视频8848| 日韩欧美国产综合在线一区二区三区 | 91美女福利视频| 日韩午夜精品电影| 一区二区欧美国产| 国产成人免费视频一区| 91精品国产综合久久久久久久 | 午夜精品免费在线| 成人晚上爱看视频| 欧美va亚洲va在线观看蝴蝶网| 亚洲欧洲av色图| 国产美女娇喘av呻吟久久| 欧美午夜免费电影| 国产精品久久久久久久午夜片| 秋霞av亚洲一区二区三| 日本道免费精品一区二区三区| 国产亚洲欧美日韩俺去了| 首页亚洲欧美制服丝腿| 91蝌蚪porny| 国产精品免费观看视频| 国内精品视频一区二区三区八戒| 欧美人与性动xxxx| 亚洲一区影音先锋| 99久久久精品| 亚洲三级电影全部在线观看高清| 国产不卡视频在线观看| 337p日本欧洲亚洲大胆精品 | 久久久99精品免费观看不卡| 全部av―极品视觉盛宴亚洲| 一本到不卡免费一区二区| 国产精品久久国产精麻豆99网站| 狠狠色丁香婷综合久久| 久久久亚洲国产美女国产盗摄 | 一本色道综合亚洲| 中文字幕视频一区二区三区久| 国产精华液一区二区三区| 欧美精品一区二区在线播放| 蜜桃视频一区二区| 日韩一区二区影院| 激情图片小说一区| 欧美mv日韩mv| 国产91精品一区二区麻豆亚洲| 久久久久99精品国产片| 国产成人精品网址| 成人欧美一区二区三区1314| 99re视频精品| 亚洲在线免费播放| 5月丁香婷婷综合| 国产一区二区三区| 中文字幕一区二区三区精华液| 99久久夜色精品国产网站| 亚洲一区欧美一区| 欧美一区二区三区公司| 精品一区二区三区欧美| 国产精品你懂的在线欣赏| 91在线视频观看| 日本午夜一区二区| 国产拍欧美日韩视频二区| 91首页免费视频| 日韩专区一卡二卡| 国产亚洲精品aa| 91电影在线观看| 国产又黄又大久久| 亚洲欧美激情在线| 欧美大片免费久久精品三p| 高清国产一区二区三区| 五月天亚洲婷婷| 国产校园另类小说区| 91福利国产成人精品照片| 黄色成人免费在线| 亚洲最大成人网4388xx| 久久影院午夜论| 欧美三级韩国三级日本三斤| 久久不见久久见免费视频7| 国产精品久久777777| 欧美一级xxx| 在线中文字幕不卡| 国产一区二区三区在线观看免费 | 欧美日韩一卡二卡三卡| 韩国欧美国产1区| 亚洲国产综合91精品麻豆| 26uuu亚洲| 51精品久久久久久久蜜臀| 国产成人精品一区二| 日韩精品成人一区二区三区| 国产精品乱码妇女bbbb| 日韩欧美国产一区二区在线播放| 91视频在线观看| 丰满少妇久久久久久久| 九九热在线视频观看这里只有精品| 亚洲精品国产精华液| 国产精品美女一区二区| www国产成人免费观看视频 深夜成人网| 在线视频综合导航| 91在线一区二区| 91在线精品一区二区| 国产乱码精品一品二品| 男人的j进女人的j一区| 丝袜美腿高跟呻吟高潮一区| 亚洲精品亚洲人成人网 | 欧美成人aa大片| 91精品国产麻豆| 91精品一区二区三区久久久久久 | 精品噜噜噜噜久久久久久久久试看 | 国产一区二区三区黄视频 | 欧美精品一卡两卡| 色成人在线视频| 在线免费观看成人短视频| 91香蕉视频mp4| 99久久婷婷国产综合精品| voyeur盗摄精品| zzijzzij亚洲日本少妇熟睡| 成人国产电影网| 99亚偷拍自图区亚洲| 色综合久久中文字幕综合网| 91免费国产在线观看| 欧美在线小视频| 3d动漫精品啪啪1区2区免费 | 三级一区在线视频先锋| 五月天亚洲精品| 美女网站色91| 国产制服丝袜一区| 99久久99久久精品免费看蜜桃| 成人白浆超碰人人人人| 色婷婷激情综合| 91精品综合久久久久久| 精品伦理精品一区| 国产精品人人做人人爽人人添| **性色生活片久久毛片| 亚洲国产精品一区二区尤物区| 日韩电影在线观看网站| 精品一区二区三区不卡| 成人激情动漫在线观看| 欧洲亚洲精品在线| 日韩免费看网站| 国产精品白丝在线| 五月婷婷综合激情| 国产91丝袜在线播放九色| av亚洲精华国产精华| 欧美一二三区在线| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 日本成人在线电影网| 国内精品国产成人国产三级粉色| 成人免费观看男女羞羞视频| 欧美视频一区二区三区| 久久夜色精品国产噜噜av| 一级做a爱片久久| 久久99精品国产.久久久久久| 不卡视频在线观看| 日韩视频一区在线观看| 亚洲天堂2014| 国产高清精品网站| 欧美日韩久久久| 国产精品国产三级国产aⅴ入口 | 亚洲日本欧美天堂| 免费在线观看视频一区| 99久久精品费精品国产一区二区| 欧美一区二区三区四区五区 | 在线电影院国产精品| 中文字幕一区二区三区四区不卡 | 91免费观看国产| 久久丝袜美腿综合| 免费看日韩a级影片| 在线观看亚洲精品视频|