从星期和年份获取日期 - 日期必须是一年中的第一天--sql

时间:2017-10-12 16:45:11

标签: sql-server date

我有一个将周和年转换为日期的查询。 但它返回确切的日期。

但我想要的是,我需要约会这一天,这与一年的第一天相同。

dateadd (week, PromisedWeek-1, dateadd (year, PromisedYear-1900, 0)) - 4 -
datepart(dw, dateadd (week, PromisedWeek-1, dateadd (year, PromisedYear-1900, 0)) - 4) + 1 

假设的例子。 我目前的查询是: 如果周是4年和2017年,则返回26-Sun-2017

我的需要: 如果一周是4周和2017年,1月1日是星期三,它应该返回2017年29-星期三。

希望你们得到我想要解释的内容。

我需要查询返回的日期与当年第1天的日期相同。

2 个答案:

答案 0 :(得分:0)

如果你有一个日历表,这很容易。日历表是包含给定范围的每个日期及其部分的表。我使用以下代码创建了我的2010年到2020年:

declare @start_dt as date = '1/1/2010';     
declare @end_dt as date = '1/1/2020';       

declare @dates as table (
 date_id date primary key,
 date_year smallint,
 date_month tinyint,
 date_day tinyint,
 weekday_id tinyint,
 weekday_nm varchar(10),
 month_nm varchar(10),
 day_of_year smallint,
 quarter_id tinyint,
 first_day_of_month date,
 last_day_of_month date,
 start_dts datetime,
 end_dts datetime
)

while @start_dt < @end_dt
begin
    insert into @dates(
        date_id, date_year, date_month, date_day, 
        weekday_id, weekday_nm, month_nm, day_of_year, quarter_id, 
        first_day_of_month, last_day_of_month, 
        start_dts, end_dts
    )   
    values(
        @start_dt, year(@start_dt), month(@start_dt), day(@start_dt), 
        datepart(weekday, @start_dt), datename(weekday, @start_dt), datename(month, @start_dt), datepart(dayofyear, @start_dt), datepart(quarter, @start_dt),
        dateadd(day,-(day(@start_dt)-1),@start_dt), dateadd(day,-(day(dateadd(month,1,@start_dt))),dateadd(month,1,@start_dt)), 
        cast(@start_dt as datetime), dateadd(second,-1,cast(dateadd(day, 1, @start_dt) as datetime))
    )
    set @start_dt = dateadd(day, 1, @start_dt)
end

select * 
into Calendar
from @dates

获得日历表后,您可以在PromisedWeek

中查询正确的工作日
declare @PromisedYear as numeric
declare @PromisedWeek as int

set @PromisedYear = 2017
set @PromisedWeek = 4

select concat(date_day, '-', weekday_nm, '-', @PromisedYear)
from Calendar as c
where 
    weekday_id = 
        (select weekday_ID 
        from Calendar 
        where date_year = @PromisedYear
            and day_of_year = 1
        )
    and datepart(week, date_id) = @PromisedWeek
    and date_year = @PromisedYear

原来,2017年1月1日是星期日,2017年的第4个星期日是1月22日,所以回报为22-Sunday-2017

答案 1 :(得分:-1)

除非我读错了,否则你自己会做得太难。就这样做:

declare @year int; set @year = 2017;
declare @week int; set @week = 4;

select dateadd(week, @week, dateadd(year, @year - 1900, 0))

结果:

2017-01-29 00:00:00.000

内部dateadd()为您提供所请求年份(1月1日)的第一天,无论工作日如何。如果是星期三,你会得到星期三。今年是星期天。外部dateadd()然后会增加整周,因此您最终会在一周的同一天结束,就像您提出的那样。

如果那不是你想要的,请解释它是如何变得更复杂的。