我正在计算所有行的列数相同?如何在SQL中有效地计算列值的出现次数?

问题描述 投票:0回答:1
Select 
       Sales_Detail.Serial_No
       ,Sales_Detail.Tax_Percentage
       ,Card_Amount
       ,Cash_Amount
       ,ISNULL((Select  Count(DISTINCT  Tax_Percentage) From Sales_Detail
        Left Join Sales_Master  ON 
        Sales_Master.Serial_No=Sales_Detail.Serial_No
        Where Sales_Master.Invoice_Date = '14-Feb-2019' 
       And IsSaved='True'And IsCancelled = 'False'
       And Card_Amount >0 Or Sales_Master.Cash_Amount>0 
       And Sales_Detail.Serial_No=10467),1) As Count_Tax    

From Sales_Detail    
Inner Join Item_Master On Sales_Detail.Item_ID = Item_Master.Item_ID
Inner Join Item_Brand On Item_Master.Brand_ID = Item_Brand.Brand_ID
Inner Join Sales_Master On Sales_Detail.Serial_No=Sales_Master.Serial_No
left Join Customer C on C.Customer_ID =Sales_Master.Customer_ID     
Inner Join Tax On Tax.Tax_Percentage=Sales_Detail.Tax_Percentage 

Where Sales_Master.Invoice_Date = '14-Feb-2019' And IsSaved = 'True' 
And IsCancelled = 'False'
order by Sales_Detail.SGST_Percentage ,Tax_Percentage

从上面查询计数。所有行都算得2。为什么这样?如果在查询中上面选择,则所有行的输出计数都为2,但实际上我想将序列号10467的count设置为1,而序列号10468则计为2。

Select
     Count(DISTINCT Tax_Percentage)
  From Sales_Detail

  Left Join Sales_Master ON Sales_Master.Serial_No=Sales_Detail.Serial_No

  Where Sales_Master.Invoice_Date = '14-Feb-2019'
  And IsSaved='True'And IsCancelled = 'False'
  And Card_Amount >0 Or Sales_Master.Cash_Amount>0
  And Sales_Detail.Serial_No=10467

enter image description here

sql sql-server-2008-r2
1个回答
0
投票

在您的选择中,您正在对Searial_No And Sales_Detail.Serial_No=10467进行硬编码,因此对于每一行,您将获得相同的值。

改变你的喜好。

Select 
       Sales_Detail.Serial_No
       ,Sales_Detail.Tax_Percentage
       ,Card_Amount
       ,Cash_Amount
       ,ISNULL((Select  Count(DISTINCT  Tax_Percentage) From Sales_Detail SD
        Left Join Sales_Master  ON 
        Sales_Master.Serial_No=SD.Serial_No
        Where Sales_Master.Invoice_Date = '14-Feb-2019' 
       And IsSaved='True'And IsCancelled = 'False'
       And Card_Amount >0 Or Sales_Master.Cash_Amount>0 
       And SD.Serial_No=Sales_Detail.Serial_No     
       ),1) As Count_Tax    

From Sales_Detail    
Inner Join Item_Master On Sales_Detail.Item_ID = Item_Master.Item_ID
Inner Join Item_Brand On Item_Master.Brand_ID = Item_Brand.Brand_ID
Inner Join Sales_Master On Sales_Detail.Serial_No=Sales_Master.Serial_No
left Join Customer C on C.Customer_ID =Sales_Master.Customer_ID     
Inner Join Tax On Tax.Tax_Percentage=Sales_Detail.Tax_Percentage 

Where Sales_Master.Invoice_Date = '14-Feb-2019' And IsSaved = 'True' 
And IsCancelled = 'False'
order by Sales_Detail.SGST_Percentage ,Tax_Percentage

建议:作为一种好的做法,总是使用表的别名,以便它可以在多个地方轻松使用而不会产生混淆。

© www.soinside.com 2019 - 2024. All rights reserved.