sql语句优化

有如下三个表
1.查询出没有选择大学物理课程的所有学生
2.查询出超过3个人选择的所有课程

student 表

 

SNONAME
1 张三
2李四
3王五
4黄七
5刘八


course 表

 

CNONAME
001大学物理
002大学英语
003C语言
004高等数学


course_select 表

 

SNO CNO
1001
1002
1003
2001
2003
3002
3003
4001
4004
5001
5002



我写的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


各位大虾看看,我写得对不对啊,还有没有更好的写法啊,还请不吝赐教!

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值