MySQL内连接排序

#student1(学生表),grade1(年级表),result(考试成绩表),subject(科目表)都在上一个博客
#查询参加考试的同学信息(学号 姓名 科目号 成绩)
SELECT s.studentNo,studentName,subjectNo,studentResult
FROM student1 s
INNER JOIN result r
ON s.studentNo = r.studentNo

#查询参加考试的同学信息(学号 姓名 科目名称 成绩)
SELECT s.studentNo,studentName,subjectName,studentResult
FROM student1 s
INNER JOIN result r
ON s.studentNo = r.studentNo
INNER JOIN subject sub
ON r.subjectNo=sub.subjectNo

#查询学学员及所属的年级(学号 学生姓名 年级名)
SELECT studentNo AS 学号,studentName AS 学生姓名,name AS 年级
FROM student1 s
INNER JOIN grade1 g
ON s.gradied1=g.id

#查询科目以及所属的年纪(科目名称 年级名称)
SELECT subjectName AS 科目名称,name AS 年级名称
FROM subject sub
INNER JOIN grade1 g
ON sub.gradeID=g.id

#查询(大学数学)的所有同学的考试结果(学号 学生姓名 科目名称 成绩)
#按照成绩由高到低排序
SELECT s.studentNo,studentName,subjectName,studentResult
FROM student1 s
#先内连接学生表和考试成绩表
INNER JOIN result r
ON s.studentNo = r.studentNo
#再内连接考试成绩表和科目表
INNER JOIN subject sub
ON r.subjectNo=sub.subjectNo
WHERE subjectName=‘大学数学’
#排序,默认为asc升序 desc为降序
ORDER BY studentResult DESC,studentNo
#常见错误:ORDER BY studentResult,studentNo DESC
#desc 和asc只修饰附近 studentResult默认升序排列 studentNo 降序排列

#查询(大学数学)的所有同学的考试结果(学号 学生姓名 科目名称 成绩)
#按照成绩由高到低排序,分页显示
#分页这里很重要,(用户体验,网络传输,查询的压力会减少)
SELECT s.studentNo,studentName,subjectName,studentResult
FROM student1 s
INNER JOIN result r
ON s.studentNo = r.studentNo
INNER JOIN subject sub
ON r.subjectNo=sub.subjectNo
WHERE subjectName=‘大学数学’
ORDER BY studentResult DESC
#从哪条记录开始(num1,num2) num1起始行 num2要显示几条
#数据记录起始行从0开始
#起始行从当前页减一乘要显示的行 num1=(当前页-1)×num2
#limit 0,1; #第一页
#limit 1,1; #第二页
LIMIT 2,1; #第三页 等同于 LIMIT 5 OFFSET 0;

#查询 大学数学 课程前3名且分数大于94分的学生信息(学号,姓名,课程名,分数)
SELECT s.studentNo AS 学号,studentName AS 姓名,subjectName AS 课程名,studentResult AS 分数
FROM student1 s
INNER JOIN result r
ON s.studentNo=r.studentNo
INNER JOIN subject sub
ON r.subjectNo=sub.subjectNo
WHERE subjectName=‘大学数学’ AND studentResult>94
ORDER BY studentResult DESC
LIMIT 0,10;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值