gpt4 book ai didi

sql - TRUNC 两次除以 0.20833333333

转载 作者:行者123 更新时间:2023-12-04 14:37:49 27 4
gpt4 key购买 nike

我来自 SQL Server 世界,有人要求我弄清楚一段(古老的)Oracle 脚本是怎么回事。

CAVEAT: I don't have access to the Oracle server, I just have the script that someone emailed me, and our copied-over data on SQL Server.

I don't have access to the tasks that have been moving the data from Oracle to SQL Server either. I'm pretty much in the dark - I have the Oracle script, and (most of) the transformed SQL Server tables.

在 Google 的帮助下,我可以很好地解释其中的大部分内容,但我终究无法弄清楚它在做什么:

decode(TRUNC((fin_time-start_time)/0.208333333333333),0,1,1,2)

我认为我已经将 decode 部分正确地解释为:

case TRUNC((fin_time-start_time)/0.208333333333333)
when 0 then 1
when 1 then 2
end

但是 TRUNC 函数让我很困惑。 endtimestarttime 是没有日期部分的时间(例如 16:00:0018:15:00 ).同样,在没有访问 Oracle 或没有任何使用 Oracle 的经验的情况下,我不知道这是否意味着有一个 TIME 数据类型,或者它是否只是一个带有“默认”日期戳的 DATETIME(例如 1900-01-01 ).无论哪种情况,日期要么不存在,要么不相关。

文档似乎表明不带格式参数传递的 TRUNC() 只会去掉时间部分。但时间部分是该列包含的全部内容。所以大概结果是 0 除以 0.2083...我要么完全走错了路,要么这是 The Daily WTF值得(或者,我怀疑,两者)。

有什么想法吗?


更新:我认为我现在已经将其正确解释为:

case floor(cast(dateadd(minute, DATEDIFF(minute, START_TIME, FIN_TIME), 0) as float) / 0.2083333333333)
when 0 then 1
when 1 then 2
end

确实似乎返回了预期值,但我认为仍然是 WTF,因为返回的值不是 0 和 1,除非我正在解释 DECODE()行为不当。我假设对于没有默认参数的非覆盖案例,它会返回 NULL(如 case 那样)?

最佳答案

在 Oracle 中减去两个日期返回一个代表天数的数字。

例子:

SELECT  TO_DATE('03.12.2004 13:00:00','DD.MM.YYYY HH24:MI:SS') 
- TO_DATE('03.12.2004 01:00:00','DD.MM.YYYY HH24:MI:SS')
from dual ;
Result: 0.5

这个表达式返回:

  • 0,如果fin_timestart_time之间的差值小于5小时,
  • 1,如果差值大于等于5小时但小于10小时,
  • null,否则。

关于sql - TRUNC 两次除以 0.20833333333,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25931685/

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