数据库建表用的decimal类型,前端传的是long类型有什么问题

数据库建表用的decimal类型,前端传的是long类型有什么问题,第1张

关于mysql数据库的数据类型numeric和decimal

decimal(numeric ) 同义,用于精确存储数值

decimal 数据类型最多可存储 38 个数字,所有数字都能够放到小数的右边。decimal 数据类型存储了一个准确(精确)的数字表达法;不存储值的近似值。

定义 decimal 的列、变量和参数的两种特性如下:

p 小数点左边和右边数字之和,不包括小数点。如 12345,则 p=5,s=2。

指定精度或对象能够控制的数字个数。

s

指定可放到小数点右边的小数位数或数字个数。

p 和 s 必须遵守以下规则:0 <= s <= p <= 38。

numeric 和 decimal 数据类型的默认最大精度值是 38。在 Transact-SQL 中,numeric 与 decimal 数据类型在功能上等效。

当数据值一定要按照指定精确存储时,可以用带有小数的 decimal 数据类型来存储数字。

转换 decimal 和 numeric 数据

对于 decimal 和 numeric 数据类型,Microsoft SQL Server 将精度和小数位数的每个特定组合看作是不同的数据类型。例如,decimal(5,5) 和 decimal(5,0) 被当作不同的数据类型。

在 Transact-SQL 语句中,带有小数点的常量自动转换为 numeric 数据值,且必然使用最小的精度和小数位数。例如,常量 12345 被转换为 numeric 值,其精度为 5,小数位为 3。

从 decimal 或 numeric 向 float 或 real 转换会导致精度损失。从 int、smallint、tinyint、float、real、money 或 smallmoney 向 decimal 或 numeric 转换会导致溢出。

默认情况下,在将数字转换为较低精度和小数位数的 decimal 或 numeric 值时,SQL Server 使用舍入法。然而,如果 SET ARITHABORT 选项为 ON,当发生溢出时,SQL Server 会出现错误。若仅损失精度和小数位数,则不会产生错误。

sql查询把decimal类型数据留两位小数法:

select convert(decimal(38, 2),Vehicle_Mode) from Vehicles

decimal在sql server里是精确值类型,精度38;在C#里是表示 128 位数据类型。double相比,decimal 类型具有更高的精度和更小的范围,它适合于财务和货币计算。

decimal:

有效位:±10 × 10(-28次方) 到 ±79 × 10(28次方)

精度:28 到 29 位

double:

有效位:±50 × 10(-324次方) 到 ±17 × 10(308次方)

精度:15 到 16 位

方法是updateCHELIANG_MINGDANsetclmd_yunxuzaizhong=cast(clmd_yunxuzaizhong/1000asdecimal(14,4))whereclmd_yunxuzaizhongisnotnullupdateCHELIANG_MINGDANsetclmd_carweight=cast(clmd_carweight/1000asdecimal(14,4))whereclmd_carweightisnotnull

sql是结构化查询语言(StructuredQueryLanguage)的简称,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。

直接给个例子。decimal(5,2) 其中 5为最多可以存储的十进制位数为5位,是小数点前后的位数总和。

2表示小数点后面的位数。同理decimal(10,2)表示十进制为10为,小数点为2,例如1111111136

,10020是合法的值,而123456,总数为6位,为非法的数据值。有人说那存12345应该可以吧。事实证明是不行的。因为其精度是2,所以12345会被当做1234500来处理,还是 非法的数据。 那么存储10011111111111111呢?经测试,数据是可以存储的,但是会丢失精度(四舍五入),数据10011会存储到数据库。

numeric和decimal同理。

p (有效位数) 可储存的最大十进位数总数,小数点左右两侧都包括在内。

s (小数位数) 小数点右侧所能储存的最大十进位数。

所以能取得最大数是38位都在小数点左边即10的38次方-1,同理最小-10的38次方+1

以上就是关于数据库建表用的decimal类型,前端传的是long类型有什么问题全部的内容,包括:数据库建表用的decimal类型,前端传的是long类型有什么问题、sql做查询怎么把decimal类型的数据保留两位小数、sqlwhere里类型转换decimal等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9407550.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存