0

以下のように、ユーザー名、更新日、およびステータスを保持するテーブルがあります。

名前 | Updated_on | 状態

akg     29-NOV-10       Active
akg     13-JAN-12       NonActive
akg     10-MAR-12       Active
ems     23-JUL-12       NonActive
ems     10-SEP-10       Active
tkp     10-SEP-10       NonActive
tkp     13-DEC-10       Active
tkp     02-JUL-12       NonActive
tkp     24-SEP-10       Active
aron    12-JAN-11       NonActive
aron    07-NOV-11       Active
aron    25-JUN-12       NonActive

このテーブルでは、ステータスを変更するたびにユーザー ステータスが更新されます (つまりusername、テーブルに示されているように、多くのエントリを持つことができます。

各ユーザーの最後から 2 番目に更新されたレコードが必要です。つまり、上記の表の場合、結果は次のようになります。

名前 | Updated_on | 状態

akg     13-JAN-12       NonActive
ems     10-SEP-10       Active
tkp     13-DEC-10       Active
aron    07-NOV-11       Active

これで各ユーザーの記録を取得したいので、私は本当に混乱しています。

これに使用できるクエリはありますか?

ありがとうございました

4

3 に答える 3

1

これを(また)Oracleでタグ付けしたとき:

select name, updated_on, status
from (
  select name, updated_on, status,
         row_number() over (partition by name order by updated_on desc) as rn,
         count(*) over (partition by name) as max_rn
  from userstatus
) 
where rn = max_rn - 1 
   or max_rn = 1;

これは実際には、MySQLではなく、さまざまなDBMS(Oracleを含む)で機能します。

于 2012-09-07T22:39:32.137 に答える
1
SELECT * FROM (
  SELECT
    rounda.*
  FROM
    userstatus AS rounda
    INNER JOIN userstatus AS roundb
      ON rounda.name=roundb.name
      AND rounda.Updated_on<roundb.Updated_On
  ORDER BY Updated_on DESC
) AS baseview
GROUP BY name

sqlfiddleを参照してください

于 2012-09-07T20:57:05.993 に答える
1

あなたはそれを試すことができます、それは少し冗長ですが、動作します:

SELECT
  name,
  max(Updated_on) as Updated_on,
  STATUS
FROM userstatus a
  WHERE (name, Updated_on) not in
  (select name, max(Updated_on) FROM userstatus group by name)
group by name, status
HAVING UPDATED_ON =
  (SELECT MAX(UPDATED_ON) FROM userstatus b where a.name = b.name
   and (b.name, b.Updated_on) not in
  (select name, max(Updated_on) FROM userstatus group by name)
  group by name);

スクフィドル

于 2012-09-07T20:59:29.007 に答える