zoukankan      html  css  js  c++  java
  • 查出选修的课的数目至少在3门以上的学生

    首先需要的建立表数据如下:

    1. create table if not exists student  
    2. (  
    3.     SNO varchar(20) primary key,  
    4.     SNAME varchar(20) character set gbk,  
    5.     AGE int,  
    6.     SEX  char(2) character set gbk CHECK(SEX IN('男','女'))   
    7. );  
    8. insert into student values('1','李强',23,'男');  
    9. insert into student values('2','刘丽',22,'女');  
    10. insert into student values('5','张友',22,'男');  
    11.   
    12. create table if not exists course  
    13. (  
    14.     CNO varchar(20) primary key,  
    15.     CNAME varchar(20) character set gbk,  
    16.     TEACHER varchar(20) character set gbk  
    17. );  
    18. insert into course values('K1','C语言','王华');  
    19. insert into course values('K5','数据库原理','程军');  
    20. insert into course values('K8','编译原理','程军');  
    21.   
    22. create table if not exists sc  
    23. (  
    24.     SNO varchar(20) NOT NULL,  
    25.     CNO varchar(20) NOT NULL,  
    26.     SCORE int NOT NULL,  
    27.     primary key (SNO,CNO),  
    28.     foreign key (SNO) references student(SNO),  
    29.     foreign key (CNO) references course(CNO)  
    30. );  
    31. insert into sc values('1','K1',83);  
    32. insert into sc values('2','K1',85);  
    33. insert into sc values('5','K1',92);  
    34. insert into sc values('2','K5',90);  
    35. insert into sc values('5','K5',84);  
    36. insert into sc values('5','K8',80);  

    方案一:

     select * from (select s.sname,count(*) num from

        student s,sc sc1,course c where s.sno=sc1.sno and c.cno=sc1.cno group by s.sno) res where res.num>=3;

    方案一得思路就是把所有学生的信息全部通过内连接查询出来,并且分组,把该结果当做是一个res表,之后再从表里通过num查询出num>=3的学生

    方案二:

     select * from student s,sc sc1,course c where s.sno=sc1.sno and c.cno=sc1.cno and group by s.sno having count(*)>=3

    方案二的思路和上面差不多,但是更为简洁,直接having语句直接分组,由代码可以看得出,having count(*)>=3相当于方案一的把结果集封装为表,再通过表的字段判断

  • 相关阅读:
    关于Python虚拟环境与包管理你应该知道的事
    你是否真的了解全局解析锁(GIL)
    谈谈装饰器的实现原理
    快速了解Python并发编程的工程实现(下)
    快速了解Python并发编程的工程实现(上)
    简单了解一下事件循环(Event Loop)
    为何你还不懂得如何使用Python协程
    一文搞懂Python可迭代、迭代器和生成器的概念
    源码分析Retrofit请求流程
    一份程序猿单词列表(updating)
  • 原文地址:https://www.cnblogs.com/Booker808-java/p/8264734.html
Copyright © 2011-2022 走看看