mysql中要存储小数用什么类型数据好?

mysql中要存储小数用什么类型数据好?,第1张

要求精度高就用decimal

审题错了...

简单写下区别:

float:浮点型,含字节数为4,32bit,数值范围为-3.4E38~3.4E38(7个有效位)

double:双精度实型,含字节数为8,64bit数值范围-1.7E308~1.7E308(15个有效位)

decimal:数字型,128bit,不存在精度损失,常用于银行帐目计算。(28个有效位)

numberic === decimal

float f = 345.98756f//结果显示为345.9876,只显示7个有效位,对最后一位数四舍五入。

double d=345.975423578631442d//结果显示为345.975423578631,只显示15个有效位,对最后一位四舍五入。

注:float和double的相乘 *** 作,数字溢出不会报错,会有精度的损失。

decimal dd=345.545454879.....//可以支持28位,对最后一位四舍五入。

注:当对decimal类型进行 *** 作时,数值会因溢出而报错。

mysql中小数点用decimal(x,y)进行存储,

示例如下,

1、创建测试表,create table test_decimal(id int, fee_value decimal(20,3))

2、插入测试数据,

insert into test_decimal values(1,12.2)

insert into test_decimal values(3,33.789)

insert into test_decimal values(6666,555.332)

3、查询表中所有记录,select * from test_decimal t

4、小数转整,可以用floor或round函数,select t.*, floor(fee_value) as fee1, round(fee_value) fee2 from test_decimal t

select 供应商名称,表二.所订产品,

case 表二.所订产品 when '产品一' then 产品一价格*数量

when '产品二' then 产品二价格*数量

when '产品三' then 产品三价格*数量

end as 应付款

from 表一 join 表二

on 表一.供应商名称=表二.供应商名称


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

原文地址: http://outofmemory.cn/zaji/8411447.html

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

发表评论

登录后才能评论

评论列表(0条)

保存