使用GoFrame ORM查询数据时,由于字段值是一个泛型对象,返回的数据类型将会被自动识别映射到Go变量类型,作为泛型的具体值。

例如:

  • 当字段类型为int(xx)时,查询到的字段值类型将会被识别会int类型
  • 当字段类型为varchar(xxx)/char(xxx)/text等类型时将会被自动识别为string类型
  • ……

以下以mysql类型为例,介绍数据库类型与Go变量类型的自动识别映射关系: 

版本可能随时迭代更新,具体可查看源码 https://github.com/gogf/gf/blob/master/database/gdb/gdb_core_structure.go 

数据库类型Go变量类型
*charstring
*textstring
*binarybytes
*blobbytes
*intint
*moneyfloat64
bitint
big_intint64
floatfloat64
doublefloat64
decimalfloat64
boolbool
datetime.Time
datetimetime.Time
timestamptime.Time
其他string

这一特性对于需要将查询结果进行编码,并通过例如JSON方式直接返回给客户端来说将会非常友好。

  • No labels

7 Comments

  1. float64 类型在通过json方式返回给客户端时,怎么保留小数位数? 

    json 期望的样子0.00,1.00,1.32 这样子;现在返回的是0,1, 如果前端根据值判断类型,就区分不出int和float

  2. 数据库 decimal 类型识别成 go float64 类型,精度不就丢失了吗,

    应该识别成原始的 []byte 类型 或者 string 类型 或者 github.com/shopspring/decimal 的 decimal 类型吧

    1. 赞同+1. 比如字段类型:decimal(30,18)   当中的值为:0.999999999999999999,取出来后float64支持的精度已经不能够满足了,会被转为1。希望官方有时间的话可以支持一下github.com/shopspring/decimal的decimal类型,或者其他能满足高精度的类型

      1. 好的,我们考虑一下哈,也欢迎大家提交贡献哈。

        1. Jay

          这个使用较为广泛,我提了pr,卡在1.15版本build&test过不去了,提示go1.17版本特性的 unsafe.Slice。

          希望尽快支持一下

  3. 为什么我设置的数据库bitint生成dao,对应的类型是uint64呢?

  4. v2.7 orm 将bool类型识别成了 string