簡體   English   中英

INNER join返回不返回總結果

[英]INNER join Return Not Returning total Results

trade_data表


id符號動作價格百分比


1 1購買3.4 50


2 1賣3.8 25


3 2賣45 75


3 2買25.2 50


符號表


身份證名


1個RCC


2 REG



選擇SUM(IF(trade_data.action ='買入,價格,0))AS'購買,SUM(IF(trade_data.action ='賣出',價格,0))AS'買入',AVG(trade_data.percent )AS標記,符號。 *從trade_data INNER JOIN symbol打開trade_data.symbol = symbol.id

此查詢給我一行,但在這種情況下有兩行可用。 但是當我更改查詢為

SELECT trade_data.* , symbol. * 
FROM  `trade_data` 
INNER JOIN  `symbol` ON trade_data.symbol = symbol.id

然后此查詢給我確切2行。

將group by與聚合函數ex一起使用。

SELECT SUM( IF( trade_data.action =  'BUY', price, 0 ) ) AS  'BUYSUM', SUM( IF( trade_data.action =  'SELL', price, 0 ) ) AS  'BUYSELL', AVG( trade_data.percent ) AS peravg, symbol. * 

FROM trade_data INNER JOIN symbol打開trade_data.symbol = symbol.id按symbol.id分組

mysql中的SUM()為您提供結果行中指定列的總和。 因此,在這里,SUM(price)將為您提供總價格,並添加每行的價格值。 總數始終是單個值,因此您將獲得單行輸出。

希望這會有所幫助。

您正在使用AVG()SUM()函數,這就是為什么您得到單個命令

The AVG() Function
The AVG() function returns the average value of a numeric column.


The SUM() Function
The SUM() function returns the total sum of a numeric column.

如果你有多個trade_data.symbol = symbol.id (超過1個ID),您可以使用GROUP BY獲得類似的ID每個記錄的總數和平均數,因為你只有1相同symbol.idtrade_data.symbol你會僅獲得一條記錄。

暫無
暫無

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

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