SQL之DECIMAL函数详解
DECIMAL 数据类型是总位数为 precision 且小数点后位数为 scale 的小数。
[折叠/展开部分] 语法
DECIMAL [ ( precision [ , scale ] ) ]
[折叠/展开部分] 参数precision 一个在 1 到 127 范围内(含 1 和 127)的整数表达式,指定表达式中的位数。缺省设置为 30。 scale 一个在 0 到 127 范围内(含 1 和 127)的整数表达式,指定小数点后的位数。小数位数值应始终小于或等于精度值。缺省设置为 6。 可以通过设置数据库选项更改缺省值。[折叠/展开部分] 注释
DECIMAL 数据类型是精确数字数据类型,其精度在算术运算后保留到最小有效位。
存储小数所需的空间可通过如下方式计算
2 + int( (before + 1)/2 ) + int( (after + 1)/2 )
函数 int 用于将其参数取整,而 before 和 after 分别是小数点之前和之后的有效位数。存储基于的是所存储的值,而不是列中允许的最大精度和小数位数。
也可以将 DECIMAL 指定为 DEC。无论使用哪种语法,都会将数据类型描述为 DECIMAL。
如果正在使用的精度是 20 或更少,正在使用的小数位数是 0,则可以改用整数数据类型(BIGINT、INTEGER、SMALLINT 或 TINYINT)之一。与具有类似有效位数的 NUMERIC 和 DECIMAL 值相比,整数值需要较少的存储空间。对整数值(例如读取或插入)和算术运算符执行的操作,通常优于对 NUMERIC 和 DECIMAL 值执行的操作。
DECIMAL 在语义上等同于 NUMERIC。
注意:如果创建 DECIMAL 数据类型的列或变量,而且其精度或小数位数超过为数据库设置的精度和小数位数,则会按照数据库设置截断这些值。因此,如果发现在定义为 DECIMAL 的列或变量中的值被截断,需检查精度和小数位数使其不超过数据库选项设置。
上一篇: c++循环语句实例
下一篇: C语言经典链表面试题分享