xorm支持各种关系数据库,最近使用postgresql时,总是踩到一些坑,在此记录下解决方式。
在使用postgresql的array类型时,查询有点问题,xorm的官方文档给出重写的方式,但是不是很清晰:
官方文档链接:http://xorm.io/docs
也就是说碰到基础库不支持的类型,需要我们去重写ToDB、FromDB方法,废话不多说直接上代码:
比如int8[]类型,自定一个Int64Array
json类型:
具体使用:
补充:golang gin xorm注意事项
1. 无论是golang还是xorm中,在填写j'son字段时,注意空格,比如 `json:"abcd "` `json:"abcd"`是不一样的,不仔细对比会出错
2.当结合gin框中的
并且使用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不要以匿名结构体的形式存在
可以改成
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/WwJoyous/article/details/80430613