推荐回答
decimal数据类型最多可存储38个数字,所有数字都能够放到小数点的右边。decimal数据类型存储了一个准确的数字表达法;不存储值的近似值。定义decimal的列、变量和参数的两种特性如下:p小数点左边和右边数字之和,不包括小数点。如123.45,则p=5,s=2。指定精度或对象能够控制的数字个数。s指定可放到小数点右边的小数位数或数字个数。p和s必须遵守以下规则:0<=s<=p<=38。numeric和decimal数据类型的默认最大精度值是38。在Transact-SQL中,numeric与decimal数据类型在功能上等效。当数据值一定要按照指定精确存储时,可以用带有小数的decimal数据类型来存储数字。转换decimal和numeric数据对于decimal和numeric数据类型,Microsoft03SQLServer64将精度和小数位数的每个特定组合看作是不同的数据类型。例如,decimal5,5和decimal5,0被当作不同的数据类型。在Transact-SQL语句中,带有小数点的常量自动转换为numeric数据值,且必然使用最小的精度和小数位数。例如,常量12.345被转换为numeric值,其精度为5,小数位为3。从decimal或numeric向float或real转换会导致精度损失。从int、smallint、tinyint、float、real、money或smallmoney向decimal或numeric转换会导致溢出。默认情况下,在将数字转换为较低精度和小数位数的decimal或numeric值时,SQLServer使用舍入法。然而,如果SETARITHABORT选项为ON,当发生溢出时,SQLServer会出现错误。若仅损失精度和小数位数,则不会产生错误。
连健儿2019-12-21 20:18:58
提示您:回答为网友贡献,仅供参考。