SQL 服务器 - 列名无效

SQL Server - Invalid column name

请帮忙,我有一个显示列 OrderNo2 的查询有问题。 以下是查询:

SELECT 
    V.id, V.TypeApv, V.CreateDate, 
    P.Requestor, VE.VendorName, V.InvoiceNo, V.Hawb, 
    PA.PaymentFor, V.Amount, V.Curr, V.DueDate, V.Remarks, V.OrderNo,
    (SELECT 
         STUFF((SELECT DISTINCT ', ' + CASE WHEN [e-SAM Case]='Subsequent' OR [e-SAM Case]='DDT' AND [Local SAP PO] LIKE '5%' OR [e-SAM Case]='FBS 4'
        THEN PoNo ELSE [Local SAP PO] END
                FROM v_copo VC
                WHERE VC.AWB1 = V.Hawb
                FOR XML PATH('')), 1, 1, '')) AS OrderNo2, 
    (SELECT ISNULL(OrderNo2, V.OrderNo)) AS OrderNoFinal
FROM
    APV_AF V
LEFT JOIN 
    APV_Person P ON P.id = V.Requestor
LEFT JOIN 
    APV_Vendor VE ON VE.IDVendor = V.VendorName
LEFT JOIN 
    APV_Payment PA ON PA.IDPayment = V.PaymentFor
ORDER BY 
    V.CreateDate DESC

您不能在定义别名的同一范围内引用别名(order by 子句除外)。典型的解决方法包括子查询或 CTE。

不过在 SQL 服务器中,一个简单的选项是横向连接:

SELECT 
    V.id, V.TypeApv, V.CreateDate, 
    P.Requestor, VE.VendorName, V.InvoiceNo, V.Hawb, 
    PA.PaymentFor, V.Amount, V.Curr, V.DueDate, V.Remarks, V.OrderNo,
    X.OrderNo2, 
    ISNULL(X.OrderNo2, V.OrderNo) AS OrderNoFinal
FROM APV_AF V
LEFT JOIN APV_Person P ON P.id = V.Requestor
LEFT JOIN APV_Vendor VE ON VE.IDVendor = V.VendorName
LEFT JOIN APV_Payment PA ON PA.IDPayment = V.PaymentFor
OUTER APPLY (
    SELECT 
        STUFF((SELECT DISTINCT ', ' + CASE WHEN [e-SAM Case]='Subsequent' OR [e-SAM Case]='DDT' AND [Local SAP PO] LIKE '5%' OR [e-SAM Case]='FBS 4'
        THEN PoNo ELSE [Local SAP PO] END
                FROM v_copo VC
                WHERE VC.AWB1 = V.Hawb
        FOR XML PATH('')), 1, 1, '') AS OrderNo2
) X
ORDER BY V.CreateDate DESC