sql - 从 SQL Server 2008 中的部分构造日期
问题描述
我正在使用 SQL Server 2008 并尝试形成一个查询,该查询将使用CASE
带有日期计算的语句来返回两个日期之一,具体取决于计算结果在月份中的哪一天。
目标是如果计算(在下面的查询中)CURRENT_TIMESTAMP + LEAD_TIME 的结果介于 1 日和 15 日之间,则指定该月的 15 日。否则,返回该月的最后一天。
例如,if CURRENT_TIMESTAMP + LEAD_TIME = 07/12/19, return 07/15/19
。 If that calculation = 07/16/19, return 07/31/19
.
这似乎可以使用DATEFROMPARTS
,但我相信因为我使用的是 SQL Server 2008,所以没有定义该函数(这是我返回的错误)。关于变通的任何想法?
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
推荐阅读
- javascript - 使用扩展运算符复制数组状态并添加所有匹配的对象
- mysql - MySQL 集群 Slave 缺少记录
- ios - 颤动的iOS设备中所有图像的目录
- php - 超时警报显示没有日志错误
- php - PHP:从长远来看,我的代码会导致问题/这是不好的做法吗?
- sql - 如何在 Oracle 的 SQL*Plus 中输出行计数计算
- android - Android 显示颜色与 ViewModel 类不同
- python - BeautifulSoup4 从 TR 中的 TD 标签中提取多个数据
- pine-script - 如何使用 pine-script 的 plotcandle() 函数
- javascript - 如果存在,如何在javascript中找到元素的索引?