使用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

2 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 类型吧