有如下三个表
1.查询出没有选择大学物理课程的所有学生
2.查询出超过3个人选择的所有课程
student 表
SNO |
NAME |
1 |
张三 |
2 |
李四 |
3 |
王五 |
4 |
黄七 |
5 |
刘八 |
course 表
CNO |
NAME |
001 |
大学物理 |
002 |
大学英语 |
003 |
C语言 |
004 |
高等数学 |
course_select 表
SNO |
CNO |
1 |
001 |
1 |
002 |
1 |
003 |
2 |
001 |
2 |
003 |
3 |
002 |
3 |
003 |
4 |
001 |
4 |
004 |
5 |
001 |
5 |
002 |
我写的sql语句如下
1. select s.sno, max(s.name) from course_select t, course c, student s
where t.cno=c.cno and t.sno=s.sno group by s.sno
having count(case when c.name ='大学物理' then s.sno end) = 0
--或者
select s.sno,s.name from student s where s.sno not in (
select distinct cs.sno from course c,course_select cs
where c.cno=cs.cno and c.name='大学物理')
2. select t.cno, t.name from (
select c.cno, c.name,count(c.cno) n from course c, course_select cs
where c.cno = cs.cno group by c.cno, c.name) t where n>3
--或者(抛兄给出的,我想应该是最优化的了。)
select t.cno, max(c.name) from course c, course_select t
where c.cno = t.cno group by t.cno having count(t.cno) > 3
各位大虾看看,我写得对不对啊,还有没有更好的写法啊,还请不吝赐教!
分享到:
相关推荐
sql语句优化之降龙十八掌 sql语句教程 sql语句优化
sql语句优化原则
2023最新mysql的sql语句优化方法技巧面试题总结.docx2023最新mysql的sql语句优化方法技巧面试题总结.docx2023最新mysql的sql语句优化方法技巧面试题总结.docx2023最新mysql的sql语句优化方法技巧面试题总结.docx2023...
SQL语句优化方法30例! 很值得下载看看!资源免费,大家分享!!
avh_-新一代智能SQL语句优化技术的ppt演示课件
sql语句优化建议,sql语句优化建议,sql语句优化建议
Sql语句优化,可以提升软件系统的效率,是很值得研究的技术
sql 语句优化 SQL Server数据库查询速度慢的原因有很多
优化数据库、SQL语句优化的原则、不要以为只有SELECT语句是查询。实际上,带有任何WHERE条件的 DML(INSERT、UPDATE、DELETE)语句中都包含查询要求,在后面的文章中,当说到查询时,不一定只是指SELECT语句,也有可能...
提供了很好的sql优化案例,对于提升sql编程能力有很大的帮助
基于索引的SQL语句优化之降龙十八掌 SQL语句优化
oracle性能优化中SQL语句优化,简单的优化思想、常见的优化命令
SQL语句最优化SQL语句最优化SQL语句最优化SQL语句最优化
Oracle——sql语句优化
sql语句优化技术分析 sql语句优化技术分析
SQL语句优化 速度第一 非常好的优化功能,希望分享
sql语句优化是软件开发最常用的方式,以提高性能的最佳办法!
客服业务受到SQL语句的影响非常大...本次秘笈根据实际的工作经验,在研发原来已有的方法的基础上,进行了一些扩充,总结了基于索引的SQL语句优化的降龙十八掌,希望有一天你能用其中一掌来驯服客服业务中横行的‘恶龙’
便于Java入门人员交流学习。可以深刻理解该语言的常用API。帮助初学者尽快入门。