gpt4 book ai didi

sql - 如何根据会计年度动态获取数据

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

如何动态创建 View 以获取基于财政年度(Financial year)的数据。

让我们看看我有样本数据的样本数据。

    Declare @t table(StartDate date )
insert into @t values('04/01/2012'),
('01/01/2012'),
('09/15/2013'),
('04/01/2014'),
('01/01/2015'),
('09/15/2015'),
('04/01/2016'),
('01/01/2017'),
('09/15/2016')

举个例子,如果我今天运行了 View ,我需要获取从 2016 年 3 月到 2017 年 4 月的数据。如果我在 2017 年 5 月运行了 View ,我需要获取从 2017 年 3 月到 2017 年 5 月的数据。我可以在 Sql server 脚本或存储过程中解决它,但如何在 Dynamic View 或 View 中获得相同的结果。建议我!

我的脚本

DECLARE @STARTDATE DATETIME, @ENDDATE DATETIME,@CURR_DATE DATETIME
SET @CURR_DATE='2016-06-01'
IF MONTH(@CURR_DATE) IN (1,2,3)
BEGIN
SET @STARTDATE= CAST( CAST(YEAR(@CURR_DATE)-1 AS VARCHAR)+'/04/01' AS DATE)
SET @ENDDATE= CAST( CAST(YEAR(@CURR_DATE) AS VARCHAR)+'/03/31' AS DATE)
END
ELSE
BEGIN
SET @STARTDATE= CAST( CAST(YEAR(@CURR_DATE) AS VARCHAR)+'/04/01' AS DATE)
SET @ENDDATE= CAST( CAST(YEAR(@CURR_DATE)+1 AS VARCHAR)+'/03/31' AS DATE)
END

select * from @t
where StartDate between
@STARTDATE AND @ENDDATE
order by year (StartDate)

它提供了我想要的财政年度(2016-2017)数据但我如何使用它并创建一个 VIEW

最佳答案

select t.*,getdate() 
from @t t
where year(startdate) * 100 + month(startdate) >=
case
when month(getdate()) in (1,2,3) then (year(getdate()) * 100) + 3 - 100
else (year(getdate()) * 100) + 3
end

关于sql - 如何根据会计年度动态获取数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37560972/

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