MySQL联合查询

MySQL联合查询,第1张

联合查询的关键字是union,连接查询的关键字是join,而在MySQL手册中,join常常被翻译成"联合查询",但绝大多数书籍和文章中,join被翻译为"连接查询",我们以书籍为准,只是翻译问题,大家注意一下。和连接查询相比,连接查询是多个表的横向组合,而联合查询则是纵向组合。

语法形式如下:

select * from 表1 inner join 表2 on 关联条件

select * from 表1 left outer join 表2 on 关联条件

select * from 表1 right outer join 表2 on 关联条件

select * from 表1 cross join 表2 on 关联条件

MYSQL查询

查询平均成绩大于70分的同学的学号和平均成绩

SELECT s.id,AVG(sc.score) FROM student s,studentcourse sc WHERE s.id=sc.student_id GROUP BY s.id HAVING  AVG(sc.score)>70

查询所有同学的学号、姓名、选课数、总成绩

SELECT id,NAME

FROM student

WHERE id NOT IN (SELECT student_id

FROM studentcourse

WHERE course_id IN (SELECT course.id

FROM teacher,course

WHERE teacher.id=course.teacher_id

AND teacher.name=’关羽’))

查询学生信息和平均成绩

SELECT s.id,s.name,s.city,s.age, c.name,sc.score,t.name

FROM student s,studentcourse sc,course c,teacher t

WHERE s.id=sc.student_id AND c.id=sc.course_id AND c.teacher_id=t.id GROUP BY s.id 


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8349358.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-15
下一篇 2023-04-15

发表评论

登录后才能评论

评论列表(0条)

保存