当前位置:Gxlcms > mysql > Row_number()OVER(PARTITIONBYxxxORDERBYXXX)分组排序_MySQL

Row_number()OVER(PARTITIONBYxxxORDERBYXXX)分组排序_MySQL

时间:2021-07-01 10:21:17 帮助过:64人阅读

  1. --//创建一个信息表
  2. CREATE TABLE user_student(id decimal(18,0) identity(1,1),st_name nvarchar(30),class nvarchar(10),score decimal(18,2))
  3. --//插入测试数据============start===================
  4. insert into user_student(st_name,class,score)
  5. values('张三','甲','90')
  6. insert into user_student(st_name,class,score)
  7. values('张四','甲','65')
  8. insert into user_student(st_name,class,score)
  9. values('张五','甲','88')
  10. insert into user_student(st_name,class,score)
  11. values('李三','乙','97')
  12. insert into user_student(st_name,class,score)
  13. values('李四','乙','88')
  14. insert into user_student(st_name,class,score)
  15. values('李五','乙','78')
  16. insert into user_student(st_name,class,score)
  17. values('王三','丙','86')
  18. insert into user_student(st_name,class,score)
  19. values('王四','丙','69')
  20. insert into user_student(st_name,class,score)
  21. values('王五','丙','59')
  22. --//插入测试数据============end===================
  23. select * from user_student
  24. --//每个班级分数前两名的学生信息
  25. SELECT ST_NAME,CLASS,SCORE
  26. FROM (
  27. SELECT Row_number() OVER(PARTITION BY CLASS ORDER BY SCORE DESC) AS NUM,*
  28. FROM user_student
  29. ) AS T
  30. WHERE NUM<=2

人气教程排行