从 SQL Server 2008 中的部分构建日期

Construct a date from parts in SQL Server 2008

我正在使用 SQL Server 2008 并尝试形成一个查询,该查询将使用 CASE 语句和日期计算 return 两个日期之一,具体取决于哪一天计算结果的月份。

目标是如果计算(在下面的查询中)CURRENT_TIMESTAMP + LEAD_TIME 结果在 1 号和 15 号之间的某一天,则分配该月的 15 号。否则,return 该月的最后一天。

例如,if CURRENT_TIMESTAMP + LEAD_TIME = 07/12/19, return 07/15/19If that calculation = 07/16/19, return 07/31/19

这似乎可以使用 DATEFROMPARTS 但我相信因为我使用的是 SQL Server 2008 该函数未定义(这是我 returning 的错误).有什么变通办法吗?

SQL:

 SELECT I.po_number, 
       I.po_item_number AS 'po_item',
       S.orderentry_date, 
       I.po_req_ship_date, 
       I.ex_factory_date, 
       I.del_indicator,
       H.po_type,
       H.vendor_no,
       CASE WHEN DATEPART(dd,(CURRENT_TIMESTAMP + MM.IAM_MAN_LEAD_TIME)) BETWEEN 1 AND 15 
            THEN DATEFROMPARTS(DATEPART(yyyy,(CURRENT_TIMESTAMP + MM.IAM_MAN_LEAD_TIME),mm,(CURRENT_TIMESTAMP + MM.IAM_MAN_LEAD_TIME),15)
            ELSE DATEFROMPARTS(DATEPART(yyyy,(CURRENT_TIMESTAMP + MM.IAM_MAN_LEAD_TIME),mm,(CURRENT_TIMESTAMP + MM.IAM_MAN_LEAD_TIME)+1,0))
            END  AS 'LT_CALC',
       H.po_created_by,
       I.comment


FROM   rbk_sap_user..vw_po_header H 
JOIN   rbk_sap_user..vw_po_item I ON H.po_number = I.po_number
JOIN   rbk_sap_user..vw_mm_material MM ON I.material = MM.material
JOIN   (SELECT order_no,
               orderentry_date 
        FROM   asagdwpdx_prod..SimoxOrder1 

        UNION ALL

        SELECT order_no,
               orderentry_date 
        FROM   asagdwpdx_prod..SimoxOrder2 

        UNION ALL 

        SELECT order_no,
               orderentry_date 
        FROM   asagdwpdx_prod..SimoxOrder3
         ) S ON S.order_no = H.ahag_number

WHERE   S.orderentry_date BETWEEN '01/31/2019' AND '02/13/2019'
AND     I.del_indicator <> 'L'
AND     H.po_type NOT IN ('02','06','10','UB')
AND     MM.business_segment_code NOT IN ('420','421','422','424')

试试这个

SELECT CAST(LEFT(CONVERT(varchar, CURRENT_TIMESTAMP + LEAD_TIME, 103 ),2) as int)

然后

CASE WHEN CAST(LEFT(CONVERT(varchar, CURRENT_TIMESTAMP + LEAD_TIME, 103 ),2) as int) < 15 THEN 
  ....
ELSE
  ....
END

您可以将日期的所有部分转换为VARCHAR并将它们串在一起为yyyy-mm-dd格式,然后CONVERTDATETIME

 SELECT 
 ...
    CASE WHEN DATEPART(dd,(CURRENT_TIMESTAMP + MM.IAM_MAN_LEAD_TIME)) BETWEEN 1 AND 15 
            THEN CONVERT(DATETIME, CONVERT(varchar, DATEPART(yyyy,(CURRENT_TIMESTAMP + MM.IAM_MAN_LEAD_TIME)))+ '-' + CONVERT(VARCHAR, DATEPART (mm,(CURRENT_TIMESTAMP + MM.IAM_MAN_LEAD_TIME)))  + '-' + CONVERT(VARCHAR, 15))
            ELSE DATEADD(DAY, -1, CONVERT(DATETIME, CONVERT(VARCHAR, DATEPART(yyyy,(CURRENT_TIMESTAMP + MM.IAM_MAN_LEAD_TIME)))+ '-' + CONVERT(VARCHAR, DATEPART(mm,CURRENT_TIMESTAMP + MM.IAM_MAN_LEAD_TIME)+ 1)  + '-' + CONVERT(VARCHAR, 1)))
            END  AS 'LT_CALC'
...

注意在ELSE语句中,获取当月最后一天的逻辑是去次月的第一天,然后使用DATEADD函数减去一个日。 The SQL Server function EOMONTH 在 SQL Server 2012 中引入,消除了对该逻辑的需求。