gpt4 book ai didi

sql - 正确的顺序是什么?应该是圆形 -> 类型转换还是类型转换 -> 圆形

转载 作者:行者123 更新时间:2023-12-02 03:34:11 25 4
gpt4 key购买 nike

当我尝试舍入时,正确的顺序应该是什么?

   ,CAST(ROUND(COUNT(FIRE_SAFETY.DATE_COMPLETED) * 100.0 / COUNT(FIRE_SAFETY.EESS_ID),2) as  decimal(16,2)) AS Percentage
,ROUND(CAST(COUNT(FIRE_SAFETY.DATE_COMPLETED) * 100.0 / COUNT(FIRE_SAFETY.EESS_ID) as decimal(16,2)),2) AS Percentage

最佳答案

如果您需要答案到小数点后两位,您应该只使用强制转换为小数(n,2)。

COUNT() 函数返回整数。当运算符组合两个不同数据类型的表达式时,数据类型优先级规则指定优先级较低的数据类型转换为优先级较高的数据类型。

因此,任何 100.0 的运算都会导致隐式十进制转换为 100.0 类型,即带小数位置。

所以下面的语句应该足够了

 ,CAST(COUNT(FIRE_SAFETY.DATE_COMPLETED) * 100.0 / COUNT(FIRE_SAFETY.EESS_ID) as decimal(16,2)) AS Percentage

参见this MSDN link 关于 SQL Server 中的精度和小数位数如何根据表达式中的组合类型受到影响。

还有 another mSDN link 关于优先规则。

关于sql - 正确的顺序是什么?应该是圆形 -> 类型转换还是类型转换 -> 圆形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50834555/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com