MAX(DATE) – SQL ORACLE

前端之家收集整理的这篇文章主要介绍了MAX(DATE) – SQL ORACLE前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想从表user_payments中只选择最新的membership_id
user_id等于1的用户.

这就是表user_payment的样子:

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

我尝试以下代码没有成功:

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

我收到这个错误
sql错误:ORA-00934:此处不允许组功能
00934. 00000 – “此处不允许群组功能

我该如何解决?提前致谢!

解决方法

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

猜你在找的MsSQL相关文章