1. ホーム
  2. sql

[解決済み] max(date) - sql oracle

2022-02-11 09:33:54

質問

user_paymentsテーブルから、最新のmembership_idだけを選択したい。 に等しいuser_idを持つユーザーの。

user_paymentテーブルはこのような感じです。

   PAYM_ID    USER_ID MEMBSHIP_ID PAYM_DATE                     
---------- ---------- ----------- -------------------------------
         1          1           1 18-DEC-09 12.00.00.000000000 AM 
         2          1           2 18-DEC-10 12.00.00.000000000 AM 
         3          1           2 18-DEC-11 12.00.00.000000000 AM 
         4          2           3 17-MAR-11 12.00.00.000000000 AM 
         5          3           3 18-JUN-12 12.00.00.000000000 AM 
         6          4           2 17-FEB-12 12.00.00.000000000 AM 
         7          5           2 18-FEB-11 12.00.00.000000000 AM 
         8          5           2 18-FEB-12 12.00.00.000000000 AM 
         9          6           1 01-JUN-12 12.00.00.000000000 AM 
        10          7           1 03-FEB-11 12.00.00.000000000 AM 
        11          7           2 03-FEB-12 12.00.00.000000000 AM 

次のコードを試していますが、うまくいきません。

SELECT MEMBSHIP_ID
FROM user_payment
WHERE user_id=1 and MAX(paym_date);

そして、こんなエラーが出ます。 SQL Error: ORA-00934: グループ関数はここでは許可されていません。 00934. 00000 - "グループ関数はここでは許可されていません"。

どうすれば直りますか?

どのように解決するのですか?

select * from 
  (SELECT MEMBSHIP_ID
   FROM user_payment WHERE user_id=1
   order by paym_date desc) 
where rownum=1;