[英]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.id
和trade_data.symbol
你會僅獲得一條記錄。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.