从位掩码确定星期几

Les*_*lie 4 sql t-sql sql-server datetime bitmask

我正在使用第三方应用程序,并尝试根据数据提取有关班次信息的有意义信息.

shift_pattern_start_dt     pattern
2014-05-27                 1111000
2015-10-25                 1110011
Run Code Online (Sandbox Code Playgroud)

2014-05-27Tuesday模式的起始位置Tuesday.所以,我想要的结果显示Tuesday,Wednesday,Thursday,和Friday.

2015-10-25Sunday这种模式的起始位置Sunday.结果应该是Sunday,Monday,Tuesday,Friday,和Saturday.

有任何想法或建议来确定正确的工作日吗?

Joh*_*tti 10

Declare @YourTable table (shift_pattern_start_dt date, pattern varchar(25))
Insert Into @YourTable values
('2014-05-27','1111000'),
('2015-10-25','1110011')

Select *
      ,NewCol = concat(
                IIF(substring(pattern,1,1)='1',   +DateName(WEEKDAY,shift_pattern_start_dt),'')
               ,IIF(substring(pattern,2,1)='1',','+DateName(WEEKDAY,dateadd(DAY,1,shift_pattern_start_dt)),null)
               ,IIF(substring(pattern,3,1)='1',','+DateName(WEEKDAY,dateadd(DAY,2,shift_pattern_start_dt)),null)
               ,IIF(substring(pattern,4,1)='1',','+DateName(WEEKDAY,dateadd(DAY,3,shift_pattern_start_dt)),null)
               ,IIF(substring(pattern,5,1)='1',','+DateName(WEEKDAY,dateadd(DAY,4,shift_pattern_start_dt)),null)
               ,IIF(substring(pattern,6,1)='1',','+DateName(WEEKDAY,dateadd(DAY,5,shift_pattern_start_dt)),null)
               ,IIF(substring(pattern,7,1)='1',','+DateName(WEEKDAY,dateadd(DAY,6,shift_pattern_start_dt)),null)
               )
 From  @YourTable
Run Code Online (Sandbox Code Playgroud)

返回

shift_pattern_start_dt  pattern   NewCol
2014-05-27              1111000   Tuesday,Wednesday,Thursday,Friday
2015-10-25              1110011   Sunday,Monday,Tuesday,Friday,Saturday
Run Code Online (Sandbox Code Playgroud)

编辑 - 交叉应用版本

Select A.*
      ,B.*
 From  @YourTable A
 Cross Apply (
                Select NewCol =Stuff((Select ',' +D 
                  From (
                        Select N,D = IIF(substring(A.pattern,N,1)='0',null,DateName(WEEKDAY,DateAdd(DAY,N-1,A.shift_pattern_start_dt)))
                         From (Values (1),(2),(3),(4),(5),(6),(7)) N(N)             
                        ) B1 
                  For XML Path ('')),1,1,'') 
             ) B
Run Code Online (Sandbox Code Playgroud)

Concat()方法的执行计划

在此输入图像描述

交叉申请方法的执行计划

在此输入图像描述