55

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

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

私の目標は、各m_idを1回取得し、最も高いタイムスタンプで並べ替えることです。

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

m_id | v_id | timestamp
------------------------
6    |   1  | 1333635349
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するため、これが原因だと思います。

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

4

8 に答える 8

65

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

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 番目のテーブルから列は選択されず、単にフィルターとして使用されます -- は「セミ結合」と呼ばれます。興味があった)
  • 行を並べ替える
于 2012-04-05T14:48:04.213 に答える
14

どのタイムスタンプを取得するかを本当に気にせず、特定のタイムスタンプv_idが常に同じであるm_i場合は、次のことができます。

select m_id, v_id, max(timestamp) from table
group by m_id, v_id
order by max(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
于 2012-04-05T14:55:10.753 に答える
5

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

 SELECT tbl.* FROM (SELECT * FROM table ORDER BY timestamp DESC) as tbl
 GROUP BY tbl.m_id  
于 2016-01-28T06:01:59.923 に答える
4

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;
于 2015-05-18T02:03:33.713 に答える
-2

なぜそんなに複雑にするのですか?これはうまくいきました。

SELECT m_id,v_id,MAX(TIMESTAMP) AS TIME
 FROM table_name 
 GROUP BY m_id
于 2018-10-02T13:18:25.253 に答える