gpt4 book ai didi

sql - Oracle 相当于 SQL Server/Sybase DateDiff

转载 作者:行者123 更新时间:2023-12-02 22:58:15 26 4
gpt4 key购买 nike

我们现在使用 NHibernate 连接到基于我们软件安装位置的不同数据库。所以我将许多 SQL 过程移植到 Oracle。

SQL Server 有一个很好的函数,称为 DateDiff,它接受日期部分、开始日期和结束日期。

日期部分示例为日、周、月、年等。 。

Oracle 的等效项是什么?

我还没有找到我必须创建自己的版本吗?

(Mark Harrison 更新) 有几个很好的答案可以解释 Oracle 日期算术。如果您需要 Oracle datediff() 请参阅 Einstein 的答案。 (我需要这个来保持 Sybase 和 Oracle 之间的 spme SQL 脚本兼容。)请注意,这个问题同样适用于 Sybase。

最佳答案

我从几年前的一篇旧汤姆文章中窃取了大部分内容,修复了文章中的一些错误并清理了它。 oracle 和 MSSQL 之间的 datediff 分界线计算方式不同,因此您必须小心周围的一些示例,这些示例没有正确考虑不提供分数结果的 MSSQL/Sybase 样式边界。

通过以下内容,您应该能够使用 MSSQL 语法并获得与 MSSQL 相同的结果,例如 SELECT DATEDIFF(dd,getdate(),DATEADD(dd,5,getdate())) FROM DUAL;

我只是声称它有效,而不是说它有效或最好的方法。我不是 Oracle 人:) 在使用我的函数宏来解决需要 dd、mm、hh、mi 等引号的问题时,您可能需要三思而后行。

(由 Mark Harrison 更新)添加 dy 函数作为 dd 的别名。

CREATE OR REPLACE FUNCTION GetDate 
RETURN date IS today date;
BEGIN
RETURN(sysdate);
END;
/

CREATE OR REPLACE FUNCTION mm RETURN VARCHAR2 IS BEGIN RETURN('mm'); END;
/
CREATE OR REPLACE FUNCTION yy RETURN VARCHAR2 IS BEGIN RETURN('yyyy'); END;
/
CREATE OR REPLACE FUNCTION dd RETURN VARCHAR2 IS BEGIN RETURN('dd'); END;
/
CREATE OR REPLACE FUNCTION dy RETURN VARCHAR2 IS BEGIN RETURN('dd'); END;
/
CREATE OR REPLACE FUNCTION hh RETURN VARCHAR2 IS BEGIN RETURN('hh'); END;
/
CREATE OR REPLACE FUNCTION mi RETURN VARCHAR2 IS BEGIN RETURN('mi'); END;
/
CREATE OR REPLACE FUNCTION ss RETURN VARCHAR2 IS BEGIN RETURN('ss'); END;
/

CREATE OR REPLACE Function DateAdd(date_type IN varchar2, offset IN integer, date_in IN date )
RETURN date IS date_returned date;
BEGIN
date_returned := CASE date_type
WHEN 'mm' THEN add_months(date_in,TRUNC(offset))
WHEN 'yyyy' THEN add_months(date_in,TRUNC(offset) * 12)
WHEN 'dd' THEN date_in + TRUNC(offset)
WHEN 'hh' THEN date_in + (TRUNC(offset) / 24)
WHEN 'mi' THEN date_in + (TRUNC(offset) /24/60)
WHEN 'ss' THEN date_in + (TRUNC(offset) /24/60/60)
END;
RETURN(date_returned);
END;
/

CREATE OR REPLACE Function DateDiff( return_type IN varchar2, date_1 IN date, date_2 IN date)
RETURN integer IS number_return integer;
BEGIN
number_return := CASE return_type
WHEN 'mm' THEN ROUND(MONTHS_BETWEEN(TRUNC(date_2,'MM'),TRUNC(date_1, 'MM')))
WHEN 'yyyy' THEN ROUND(MONTHS_BETWEEN(TRUNC(date_2,'YYYY'), TRUNC(date_1, 'YYYY')))/12
WHEN 'dd' THEN ROUND((TRUNC(date_2,'DD') - TRUNC(date_1, 'DD')))
WHEN 'hh' THEN (TRUNC(date_2,'HH') - TRUNC(date_1,'HH')) * 24
WHEN 'mi' THEN (TRUNC(date_2,'MI') - TRUNC(date_1,'MI')) * 24 * 60
WHEN 'ss' THEN (date_2 - date_1) * 24 * 60 * 60
END;
RETURN(number_return);
END;
/

关于sql - Oracle 相当于 SQL Server/Sybase DateDiff,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43819/

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