红移和和轮函数差异
Posted
技术标签:
【中文标题】红移和和轮函数差异【英文标题】:Redshift sum and round function discrepancy 【发布时间】:2020-07-27 18:20:51 【问题描述】:应用了 sum 和 round 函数,一些值在 Redshift 中没有正确生成。
round((field1+field2),1)
【问题讨论】:
我想你是说所有突出显示的行都应该具有相同的值,因为它们是舍入73.45
? a
和 b
是否有可能实际上有更多数字,但您的 SQL 客户端没有显示它们?尝试select a::text, b::text from ...
查看这些字段中的原始值。
是的,你是对的,还有一个帮助,我们可以将 73.43 转换为 73.5 吗?
您会为这种转换应用什么规则?它是“去最接近的 .5”吗?也许ROUND(value*2,0)/2
?
【参考方案1】:
当 SQL 查询产生奇怪的结果时,您的 SQL 客户端可能正在对屏幕上显示的值进行四舍五入。
要检查这一点,将数字转换为文本以显示它们在数据库中的真实值,防止它们被您的 SQL 客户端修改。
例如:
SELECT a, a::TEXT, b, b::TEXT
【讨论】:
以上是关于红移和和轮函数差异的主要内容,如果未能解决你的问题,请参考以下文章