如果另一个日期字段是前一个工作日,则TSQL仅提取数据

时间:2016-04-07 22:33:08

标签: sql sql-server tsql

1)如果openddate等于PrevBiz日期,我只需要提取数据。我认为where /和语句是Openddate = PrevBiz,但不确定。它对我不起作用,可能是因为日期格式不匹配。有什么建议吗?

   DECLARE @TODAY       DATE    = GETDATE()
    DECLARE @PREVFIRST  CHAR(8) = CONVERT(CHAR(8), DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE()) - 1, 0), 112)
DECLARE @PREVLAST   CHAR(8) = CONVERT(CHAR(8), DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE()), -1), 112) 
        DECLARE @PREVBIZ    CHAR(12) = DATEADD(DAY, CASE DATENAME(WEEKDAY, CONVERT(CHAR(12), @TODAY,112))
                            WHEN 'SUNDAY' THEN -2
                            WHEN 'MONDAY' THEN -3
                            ELSE -1 END, DATEDIFF(DAY, 0, CONVERT(CHAR(12), @TODAY, 112)))

          SELECT TOP 10
          CURRENTDATE       =@TODAY, 
          FIRST_OF_MONTH    =@PREVFIRST,
          LASTDAY_OFMONTH   =@PREVLAST,
          PREVBIZ           =@PREVBIZ,

           DATEADD(DAY, CASE DATENAME(WEEKDAY, CONVERT(DATE, @TODAY,101))
            WHEN 'SUNDAY' THEN -2
            WHEN 'MONDAY' THEN -3
            ELSE -1 END, DATEDIFF(DAY, 0, CONVERT(DATE, @TODAY, 101))) AS PREVIOUSBIZDATE,

          OpendDate 

          FROM [USBI_DW].[USBI].[vw_NameAddressBase]
          where IsCurrent = 1

这是我的结果: enter image description here

1 个答案:

答案 0 :(得分:2)

declare @TODAY datetime   = convert(date,GETDATE())
declare @PREVBIZ   datetime =  DATEADD(DAY, CASE DATENAME(WEEKDAY,@TODAY)
                            WHEN 'SUNDAY' THEN -2
                            WHEN 'MONDAY' THEN -3
                            ELSE -1 END,@TODAY)
declare @iToday int = convert(nvarchar(8),@TODAY, 112)
      , @iPrevBiz int = convert(nvarchar(8),@PREVBIZ, 112)

select top 10
      CURRENTDATE       =@iToday,
      PREVBIZ           =@iPrevBiz,
      OpendDate 

from [USBI_DW].[USBI].[vw_NameAddressBase]
where IsCurrent = 1
and OprendDate = @iPrevBiz

希望您的视图包含int date属性(因为DateWarehouse特定)