微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

将 SQL 过滤为一个值?

如何解决将 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 举报,一经查实,本站将立刻删除。