需要在 Oracle 11g DB 中创建财政年度条目

Posted

技术标签:

【中文标题】需要在 Oracle 11g DB 中创建财政年度条目【英文标题】:Need to create Financial Year entries in Oracle 11g DB 【发布时间】:2012-12-28 07:27:20 【问题描述】:

我需要基于 Oracle11g DB 中当前或今天的日期和时间的财政年度条目。

假设如果我们考虑今天的日期是 2013 年 4 月 1 日,那么我需要输出为 01-APR-1331-MAR-14

我们考虑的财政年度要求是从 4 月(当年)到 3 月(下一年)。

基于当前日期时间...输出方案取决于当前日期时间,该日期时间属于上述时间段或持续时间。

另一个例子:如果我们将今天的日期时间设为 2012 年 12 月 28 日,则需要输出为 01-APR-1231-MAR-13

请帮助如何仅使用 SQL 以非常短的格式实现相同的目标。

将下表视为

Create table venky (financialYearFrom DATE NOTNULL, financialYearTo DATE NOTNULL);

【问题讨论】:

【参考方案1】:

丑陋的东西:

   SELECT to_date('1-APR-'||(to_char(sysdate,'yyyy')+
                                (case when to_char(sysdate,'mm')>3 
                                 then 0 
                                 else -1 
                                 end))) AS start_date ,
      to_date('31-MAR-'||(to_char(sysdate,'yyyy')+
                                 (case when to_char(sysdate,'mm')>3 
                                  then 1 
                                  else 0 
                                  end))) end_date 
   FROM dual;

如果month > 3 则在31-MAR(end_of_period) 中加上一年,否则在1-APR (start_of_period) 中减去一年。

更新:更好的东西:

select add_months(trunc(add_months(sysdate,-3),'yyyy'),3) as start_date ,
    add_months(trunc(add_months(sysdate,-3),'yyyy'),15)-1 as end_date 
   from dual

减去 3 个月后,您将进入正确的开始年份。截断年份并加上 3 个月会将您发送到 1 APR。 end_of 期间是开始前 12 个月减去一天。

【讨论】:

:太酷了!!!!!!万分感谢 !!!!但这可以简化吗?因为我将在子查询中使用它。 我添加了另一个解决方案。 伙计们......如果你觉得这个问题是真实的,那么请投票给这个问题......谢谢!!!【参考方案2】:

为此创建用户定义函数,这里是 SQL SERVER 的示例 找到如何在 oracle 中执行此操作(两者在语法上略有不同)

CREATE FUNCTION [dbo].[getYear] 
(
    -- Add the parameters for the function here
    @CurDate DATETIME
)
RETURNS VARCHAR(MAX)
AS
BEGIN
    DECLARE @Y int;
    SELECT @Y = CASE WHEN MONTH(@CurDate) <= 3 THEN YEAR(@CurDate) - 1 ELSE YEAR(@CurDate) END;

    RETURN '01-APR-' + LTRIM(STR(@Y)) + ' and 31-MAR-' + LTRIM(STR(@Y+1));
END

并像这样使用它

Select dbo.GETYEAR(GETDATE());

【讨论】:

这个想法很好,但是:1)用户想要纯sql(虽然deterministic函数我确定没问题)。 2)如果我在 sql server 问题上编写 PL/SQL,几乎可以肯定我会得到“拳头”:)

以上是关于需要在 Oracle 11g DB 中创建财政年度条目的主要内容,如果未能解决你的问题,请参考以下文章

在 Oracle 11g 中创建触发器的问题

如何在Oracle 11g 中创建用户并授予权限

如何在 Oracle 11g 中创建自动增量?

在Oracle 11g 中创建表时如何保存表?

如何在oracle sql developer中按年和月分组获取当前财政年度的数据?

在 PHP 中创建 PDF 页面