红移和和轮函数差异

Posted

技术标签:

【中文标题】红移和和轮函数差异【英文标题】:Redshift sum and round function discrepancy 【发布时间】:2020-07-27 18:20:51 【问题描述】:

应用了 sum 和 round 函数,一些值在 Redshift 中没有正确生成。

round((field1+field2),1) 

【问题讨论】:

我想你是说所有突出显示的行都应该具有相同的值,因为它们是舍入 73.45ab 是否有可能实际上有更多数字,但您的 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

【讨论】:

以上是关于红移和和轮函数差异的主要内容,如果未能解决你的问题,请参考以下文章

用于更改列的红移窗口函数

您可以在窗口函数中包含除法吗(红移)

如何从 lambda 函数异步传递红移查询?

LTC6804 起动导线开路ADC转换和轮询转换指令(ADOW)

获取最后一个不同值的滞后函数(红移)

使用字符串函数反序列化亚马逊红移中的 php 对象