【发布时间】:2016-09-30 08:49:25
【问题描述】:
如何动态创建视图以获取基于财政年度(财政年度)的数据。
让我们看看我有样本数据的样本数据。
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')
举个例子,如果我今天运行了视图,我需要从 2016 年 3 月到 2017 年 4 月。如果我在 2017 年 5 月运行视图,我需要从 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
【问题讨论】:
-
您能否详细说明究竟是什么决定了您的查询的开始/结束日期?
标签: sql sql-server tsql view dynamic-view