如何解决将 SQL 过滤为一个值?
我正在使用 Microsoft sql Server Management Studio 17 为 SAP B1 编写查询。
我想返回“MIN”DocDate,但在它旁边显示字段“ShipDate”,只有一个结果...
SELECT T0.ItemCode,T3.ShipDate AS 'Next Date',MIN(T3.DocDate) AS 'OrderDate'
FROM OITM T0
LEFT OUTER JOIN POR1 T3 ON T0.ItemCode = T3.ItemCode
WHERE T3.Linestatus = 'O' AND T3.ShipDate > GETDATE()
Group By T0.Itemcode,T3.ShipDate
这将返回以下结果;
项目代码 | 发货日期 | 订单日期 |
---|---|---|
VT3021026 | 2021-05-14 | 2021-05-04 |
VT3021026 | 2021-06-01 | 2021-05-10 |
这是一个返回单个项目的示例,但是我只想为每个项目返回一个值。几乎就像每个单独项目的“TOP 1”。 (显然 top 1 在整个 select 子句中不起作用,因为它需要生成多个项目的列表)
解决方法
如果我理解正确,那么此代码将解决问题。
DECLARE @date datetime2 = GETDATE();
WITH T(ItemCode,OrderDate) AS
(
SELECT
T0.ItemCode,MIN(T3.DocDate) AS 'OrderDate'
FROM OITM T0
LEFT JOIN POR1 T3
ON T0.ItemCode = T3.ItemCode
WHERE T3.LineStatus = 'O'
AND T3.ShipDate > @date
GROUP BY T0.Itemcode,T3.ShipDate
)
SELECT T.ItemCode,T4.ShipDate AS 'Next Date',T.OrderDate
FROM T
LEFT JOIN POR1 T4
ON T.[OrderDate] = T4.DocDate
AND T.ItemCode = t4.ItemCode;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。