web-dev-qa-db-ja.com

ORDER BYとGROUP BYを一緒に使用する

私のテーブルは次のようになります(そしてMySQLを使用しています):

m_id | v_id | timestamp
------------------------
6    |   1  | 1333635317
34   |   1  | 1333635323
34   |   1  | 1333635336
6    |   1  | 1333635343
6    |   1  | 1333635349

私の目標は、各m_idを一度取得し、最高のタイムスタンプで並べることです。

結果は次のようになります。

m_id | v_id | timestamp
------------------------
6    |   1  | 1333635343
34   |   1  | 1333635336

そして、私はこのクエリを書きました:

SELECT * FROM table GROUP BY m_id ORDER BY timestamp DESC

しかし、結果は次のとおりです。

m_id | v_id | timestamp
------------------------
34   |   1  | 1333635323
6    |   1  | 1333635317

原因は、最初にGROUP_BYを実行し、次に結果をORDERするためだと思います。

何か案は?ありがとうございました。

39
Luis

group byを正しく使用するこれを行う1つの方法:

select l.* 
from table l
inner join (
  select 
    m_id, max(timestamp) as latest 
  from table 
  group by m_id
) r
  on l.timestamp = r.latest and l.m_id = r.m_id
order by timestamp desc

仕組み:

  • サブクエリの個別のm_idの最新のタイムスタンプを選択します
  • サブクエリの行と一致するtableの行のみを選択します(この操作-結合が実行されますが、2番目のテーブルから列が選択されず、フィルターとして使用されるだけです-は、 "semijoin" 興味があった場合)
  • 行を順序付けます
46
Matt Fenwick

どのタイムスタンプを取得するかを本当に気にせず、v_idが与えられたm_iに対して常に同じである場合、次のことができます。

select m_id, v_id, max(timestamp) from table
group by m_id, v_id
order by timestamp desc

v_idが特定のm_idに対して変更された場合、次のことを行う必要があります。

select t1.* from table t1
left join table t2 on t1.m_id = t2.m_id and t1.timestamp < t2.timestamp
where t2.timestamp is null
order by t1.timestamp desc
7
Mosty Mostacho

これを試すことができます

 SELECT tbl.* FROM (SELECT * FROM table ORDER BY timestamp DESC) as tbl
 GROUP BY tbl.m_id  
5
Ronak Patel

SQL>

SELECT interview.qtrcode QTR, interview.companyname "Company Name", interview.division Division 
FROM interview 
JOIN jobsdev.employer 
    ON (interview.companyname = employer.companyname AND employer.zipcode like '100%')
GROUP BY interview.qtrcode, interview.companyname, interview.division
ORDER BY interview.qtrcode;
4
Go ahead

これが最も簡単な解決策です

select m_id,v_id,max(timestamp) from table group by m_id;

M_idでグループ化しますが、各m_idのタイムスタンプの最大値を取得します。

2
abinash sahoo

Ascで説明する必要があります。以下のようなクエリを作成します。値を昇順で返します。

SELECT * FROM table GROUP BY m_id ORDER BY m_id asc;
2
Gurpreet Singh