标签:mysql casting division multiprecision
如何在MySQL中正确划分两个DECIMAL值并获得精确到列类型中定义的位数的结果?
例:
select cast(1/2 as decimal(4,4)),
cast(1 as decimal(4,4))/2,
cast(1 as decimal(4,4))/cast(2 as decimal(4,4));
结果:
'0.5000', '0.49995000', '1.00000000'
为什么第二个结果是否真空?为什么第三个结果不是“0.5000”?
注意:我不能只使用第一个表单,我需要使用存储为小数的列执行计算.
解决方法:
问题是DECIMAL数据类型声明需要2个参数,第一个是总位数,包括小数部分.
根据文档(http://dev.mysql.com/doc/refman/5.7/en/precision-math-decimal-characteristics.html):
The declaration syntax for a DECIMAL column is DECIMAL(M,D). The
ranges of values for the arguments in MySQL 5.1 are as follows:M is the maximum number of digits (the precision). It has a range of 1
to 65. (Older versions of MySQL permitted a range of 1 to 254.)D is the number of digits to the right of the decimal point (the
scale). It has a range of 0 to 30 and must be no larger than M.
所以,如果你使用5位数而不是4位数,一切正常:
select cast(1/2 as decimal(5,4)),
cast(1 as decimal(5,4))/2,
cast(1 as decimal(5,4))/cast(2 as decimal(5,4)),
cast(cast(1 as decimal(5,4))/cast(2 as decimal(5,4)) as decimal(5,4));
结果
0.5000, 0.50000000, 0.50000000, 0.5000
标签:mysql,casting,division,multiprecision 来源: https://codeday.me/bug/20190609/1205371.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。