人力検索はてな
モバイル版を表示しています。PC版はこちら
i-mobile

[postgresql]下記のような承認履歴テーブルがあります
id , userid , requestno, flg
1 , hoge@ , 1001, 却下
2 , uge@ , 1001, 未承認
3 , hoge@ , 1001, 承認
以下続く

idは連番、useridの個数は不定です
useridごとに最後(idが一番大きい)の承認結果をSQLでだしたいのですがどうすればよいでしょうか
上の例だと2と3のみ抽出したく。

●質問者: piro_yamagoo
●カテゴリ:コンピュータ ウェブ制作
✍キーワード:hoge postgreSQL SQL 却下 承認
○ 状態 :終了
└ 回答数 : 1/1件

▽最新の回答へ

1 ●
●60ポイント
SELECT *
FROM sample_table a
WHERE a.id = ( SELECT max(b.id)
 FROM sample_table b
 WHERE a.userid = b.userid )
;

こんな感じでいかがでしょうか。

テーブル名は仮に「sample_table」としております。

(requestnoの意味が分からなかったため、意識しませんでした。)

◎質問者からの返答

ビンゴです。自己結合をつかうのですね。

SQL奥深いです。

関連質問


●質問をもっと探す●



0.人力検索はてなトップ
8.このページを友達に紹介
9.このページの先頭へ
対応機種一覧
お問い合わせ
ヘルプ/お知らせ
ログイン
無料ユーザー登録
はてなトップ