sql语句优化

xiaoxiao2026-06-15  4

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

 

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

course 表

 

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

course_select 表

 

SNO CNO 10011002100320012003300230034001400450015002

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

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

 

转载请注明原文地址: https://www.6miu.com/read-5050190.html

最新回复(0)