float 和 real
用于表示浮点数字数据的近似数字数据类型。浮点数据为近似值;并非数据类型范围内的所有数据都能精确地表示。
如果使用float4或者float8类型,新增后生成的浮点类型小数无法满足需求。栗子如下图
例如: 1000.345
float4—>1000.3459998
float8—>1000.34599999998
显然这样的数据是不符合设置好的浮点类型数据。
注:
由于金仓数据库字段没有Double类型,如果实体需要Double类型字段,数据库字段建议使用 decimal(12,3)或者 numeric(12,3) 来代替float
decimal[(p[, s])] 和 numeric[(p[, s])]
p(精度)
指定小数点左边和右边可以存储的十进制数字的最大个数。精度必须是从 1 到最大精度之间的值。最大精度为 38。s(小数位数)
指定小数点右边可以存储的十进制数字的最大个数。小数位数必须是从 0 到 p 之间的值。默认小数位数是 0,因而 0 <= s
<= p。最大存储大小基于精度而变化。