簡體   English   中英

如何在case語句中編寫select語句

[英]how to write the select statement in case statement

讓我知道如何在case語句中編寫select查詢。

select
ROW_NUMBER() OVER(Order by vendor.VendorName ) AS ID,
PH.PurchasingHeaderID as BILLNo,
PH.TotalPriceCompanyCurrency as Balance,
acc.AccountName as [Account_Name]  
**Into #tempOpenVedorlist** 
from PurchasingHeader PH
LEFT OUTER JOIN TransactionType Trans ON PH.TransactionTypeID =Trans.TransactionTypeID
LEFT OUTER JOIN Vendor vendor on PH.VendorID=vendor.VendorID
LEFT OUTER JOIN PaymentTerm PT on PT.PaymentTermID = vendor.PaymentTermID
LEFT OUTER JOIN PurchasingDetail PD on PD.PurchasingHeaderID = PH.PurchasingHeaderI
LEFT OUTER JOIN Account Acc on Acc.AccountID= PD.FinancialAccountID 
where PH.TransactionTypeID=7
Group by vendor.VendorName,
PH.PurchasingHeaderID,PH.TotalPriceCompanyCurrency,acc.AccountName

我得出這個結果:

結果如下:這里我有No:VB1003兩次,但帳號名稱不同。

ID      BILLNo          Account_Name            Balance   
-------------------------------------------------------------
 101      VB1000        Cash-Petty Cash         4000.00  
 102     VB1001        Accounts Receivable      5000.00 
 103    VB1003       Cash-PettyCash             6000.00 
 104     VB1003       Cash                      6000.00  
 105    VB1004        UndepositedFunds          7000.00  

在這里我要表現出來;

我需要這個結果:

ID      BILLNo        Account_Name          Balance    
------------------------------------------------------
 101      VB1000      Cash-PettyCash        4000.00  
 102      VB1001      AccountsReceivable     5000.00  
 103     VB1003      ---Multiple----        6000.00  
 104     VB1004      UndepositedFunds      7000.00   

對於aboue結果我所做的:我已經獲取了臨時表中的所有數據。

能夠顯示多個字符串,其中包含多個字符串。

但不幸的是,我無法顯示只有一個BILLNo的帳戶名稱。

select ROW_NUMBER() OVER(Order by BILLNo ) AS ID,
[BILLNo],
Balance,
 CASE
 WHEN count(BILLNo)>1 THEN 'Multipul'
 WHEN count(BILLNo)<2 THEN **(Select Account_Name from #tempOpenVedorlist )** 
 End As [Financial_Account] 
from #tempOpenVedorlist
Group By BILLNo,Balance

讓我知道如何從臨時表中獲取與該BILLNo相關的帳戶名稱。

GROUP BY刪除AccountName並在其上放置聚合。

SELECT  ROW_NUMBER() OVER(Order by vendor.VendorName ) AS ID,
        PH.PurchasingHeaderID as BILLNo,
        PH.TotalPriceCompanyCurrency as Balance,
        CASE WHEN MIN(acc.AccountName) IS NULL
             THEN '----'
             WHEN MIN(acc.AccountName) = MAX(acc.AccountName)
             THEN MIN(acc.AccountName) 
             ELSE '--MULTIPLE--' 
        END  as [Account_Name]  
INTO    #tempOpenVedorlist
FROM    PurchasingHeader PH
        LEFT OUTER JOIN TransactionType Trans 
            ON PH.TransactionTypeID =Trans.TransactionTypeID
        LEFT OUTER JOIN Vendor vendor 
            ON PH.VendorID=vendor.VendorID
        LEFT OUTER JOIN PaymentTerm PT 
            ON PT.PaymentTermID = vendor.PaymentTermID
        LEFT OUTER JOIN PurchasingDetail PD 
            ON PD.PurchasingHeaderID = PH.PurchasingHeaderI
        LEFT OUTER JOIN Account Acc 
            ON Acc.AccountID= PD.FinancialAccountID 
WHERE   PH.TransactionTypeID=7
GROUP BY  vendor.VendorName,
        PH.PurchasingHeaderID,
        PH.TotalPriceCompanyCurrency

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM