簡體   English   中英

SQL查詢花費“太長”的時間-選擇與眾不同和最大

[英]SQL query taking “too” long - select with distinct and max

我有這種情況:

一個帶有POSITION和每個位置相關聯的值的表,但是同一位置我總是有4個值,因此我的表的示例是:

position | x| values 
1 | x1 | 0
1 | x2 | 1
1 | x3 | 1.4
1 | x4 | 2
2 | x1 | 3
2 | x2 | 10
2 | x3 | 12.4
2 | x4 | 22

我需要一個查詢,該查詢返回每個唯一位置值的最大值。 現在,我在查詢它:

SELECT DISTINCT (position) AS p, (SELECT MAX(values) AS v FROM MYTABLE  WHERE position = p) FROM MYTABLE;

我花了1651行(39.93秒),而1651行只是對該數據庫的測試(可能應該有1651行以上)。

我究竟做錯了什么 ? 有沒有更好的方法可以更快地獲得它?

任何幫助表示贊賞。 干杯。,

使用GroupBy-Clause:

SELECT Position, MAX(VALUES) FROM TableName
GROUP BY Position

另外,請參閱文檔(關於groupby): http : //dev.mysql.com/doc/refman/5.0/en/group-by-functions.html

嘗試使用GROUP BY子句:

SELECT position AS p, MAX(values) AS v
FROM MYTABLE
GROUP BY p;

嘗試這個

 SELECT position AS p, MAX(`values`) AS v FROM MYTABLE 
 GROUP BY position 

此處演示

輸出:

    P | V
    1 | 2
    2 | 22

暫無
暫無

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

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