第九章 MySQL中LIMIT和NOT IN案例

一.案例的项目

1.创建数据库语句:

#创建数据库

CREATE DATABASE `schoolDB`;

USE `schoolDB`;

#创建学生表

CREATE TABLE `student`(

`sid` INT(4) AUTO_INCREMENT NOT NULL PRIMARY KEY COMMENT‘学生编号‘,

`stuName` VARCHAR(10) NOT NULL COMMENT‘学生姓名‘,

`age` INT(4) NOT NULL COMMENT‘年龄‘,

`sex` INT(1) NOT NULL COMMENT‘学生性别‘

)ENGINE=INNODB DEFAULT CHARSET=utf8 COMMENT=‘学生信息表‘;

#创建课程表

CREATE TABLE `course`(

`cid` INT(4) PRIMARY KEY COMMENT‘课程编号‘,

`cName` VARCHAR(50) NOT NULL COMMENT‘课程名称‘,

`tid` INT(4) NOT NULL COMMENT‘教师编号‘

)ENGINE=INNODB DEFAULT CHARSET=utf8 COMMENT=‘课程信息表‘;

#创建成绩表

CREATE TABLE `score`(

`sid` INT(4) COMMENT‘学生编号‘,

`cid` INT(4) COMMENT‘课程便号‘,

`score` INT(4) NOT NULL COMMENT‘成绩‘

)ENGINE=INNODB DEFAULT CHARSET=utf8 COMMENT=‘成绩表‘;

#创建教师 表

CREATE TABLE `teacher`(

`tid` INT(4) PRIMARY KEY COMMENT‘教师编号‘,

`teaName` VARCHAR(50) NOT NULL COMMENT‘教师姓名‘

)ENGINE=INNODB DEFAULT CHARSET=utf8 COMMENT=‘教师信息表‘;

#创建`score表`主键

ALTER TABLE `score` ADD CONSTRAINT `pk_score` PRIMARY KEY `score`(`sid`,`cid`);

#创建课程表外键外键关联 教师表 教师编号

ALTER TABLE `course` ADD CONSTRAINT `fk_course_teacher` FOREIGN KEY (`tid`) REFERENCES `teacher`(`tid`);

#创建成绩表外键关联 学生表 学生编号

ALTER TABLE `score` ADD CONSTRAINT `fk_score_student` FOREIGN KEY (`sid`) REFERENCES `student`(`sid`);

#创建成绩表外键关联 课程表 课程编号

ALTER TABLE `score` ADD CONSTRAINT `fk_score_course` FOREIGN KEY (`cid`) REFERENCES `course`(`cid`);

#插入学生表 数据

INSERT INTO `student` VALUES(1,‘张三‘,16,1);

INSERT INTO `student` VALUES(2,‘李三思‘,17,1);

INSERT INTO `student` VALUES(3,‘李大齐‘,16,1);

INSERT INTO `student` VALUES(4,‘王晓花‘,16,0);

INSERT INTO `student` VALUES(5,‘刘得住‘,17,1);

INSERT INTO `student` VALUES(6,‘谢谢你‘,16,1);

INSERT INTO `student` VALUES(7,‘吴三桂‘,16,1);

INSERT INTO `student` VALUES(8,‘桂花‘,16,0);

#插入教师表 数据

INSERT INTO `teacher` VALUES(101,‘朱大胖‘);

INSERT INTO `teacher` VALUES(102,‘方芳‘);

INSERT INTO `teacher` VALUES(103,‘刘博士‘);

#插入课程表 数据

INSERT INTO `course` VALUES(1011,‘语文‘,101);

INSERT INTO `course` VALUES(1012,‘英语‘,102);

INSERT INTO `course` VALUES(1013,‘数学‘,103);

#插入成绩表 数据

INSERT INTO `score` VALUES(1,1011,90);

INSERT INTO `score` VALUES(1,1012,70);

INSERT INTO `score` VALUES(1,1013,60);

INSERT INTO `score` VALUES(2,1011,88);

INSERT INTO `score` VALUES(2,1012,70);

INSERT INTO `score` VALUES(2,1013,70);

INSERT INTO `score` VALUES(3,1011,92);

INSERT INTO `score` VALUES(3,1012,71);

INSERT INTO `score` VALUES(3,1013,65);

INSERT INTO `score` VALUES(4,1011,99);

INSERT INTO `score` VALUES(4,1012,78);

INSERT INTO `score` VALUES(4,1013,88);

INSERT INTO `score` VALUES(5,1011,87);

INSERT INTO `score` VALUES(5,1012,79);

INSERT INTO `score` VALUES(5,1013,62);

INSERT INTO `score` VALUES(6,1011,56);

INSERT INTO `score` VALUES(6,1012,65);

INSERT INTO `score` VALUES(6,1013,75);

INSERT INTO `score` VALUES(7,1011,50);

INSERT INTO `score` VALUES(7,1012,55);

INSERT INTO `score` VALUES(7,1013,51);

INSERT INTO `score` VALUES(8,1011,95);

INSERT INTO `score` VALUES(8,1012,59);

INSERT INTO `score` VALUES(8,1013,64);

2.执行SQL查询

USE `schooldb`;

/*1.查询学过“方芳”老师所教课程的学生的学号、姓名。(假定学生所学的课程均参加了考试)。*/

#测试通过

SELECT `sid`,`stuName` FROM `student` WHERE `sid` IN(

SELECT `sid` FROM `score` WHERE `cid`=(

SELECT `cid` FROM `course` WHERE `tid`=(

SELECT `tid` FROM `teacher` WHERE `teaName`=‘方芳‘

)

)

);

3.NOT IN取反的经典应用

/*2.查询所有课程成绩均小于60分的学生学号和姓名。*/

#改一下数据才有符合要求的数据

UPDATE `score` SET `score`=50 WHERE `sid`=7 AND `cid`=1013;

SELECT `sid`,`stuName` FROM `student` WHERE `sid` NOT IN(

SELECT `sid` FROM `score`

WHERE `score`>60

);

/*难点:步骤分析:

1.查询所有分数大于60的学生编号

2.取反,不在所有大于60分的里面的学生,就是所有成绩小于60的学生

*/

4.LIMIT不支持子查询的解决方法

/*3.查询“方芳”老师所教的“数据库”课程成绩排名在第3~6名的学生学号、姓名,

并将此记录插入新表tempScore中。(要求使用limit子句)*/

CREATE TABLE `tempScore`(

SELECT `sid`,`stuName` FROM `student` WHERE `sid` IN(

#查询方芳老师所教课程第3-6名学员的编号

SELECT `sid` FROM(

SELECT `sid` FROM `score` WHERE `cid` IN(

SELECT `cid` FROM `course` WHERE `tid`=(

SELECT `tid` FROM `teacher` WHERE `teaName`=‘方芳‘

)

)GROUP BY `score` DESC LIMIT 2,4

)AS ta

)

);

/*难点:问题出现在mysql不支持在子查询中使用limit报错:This version of MySQL doesn’t yet support ‘LIMIT & IN/ALL/ANY/SOME subquery

解决的方法是:在limit子句外面加上一层查询"SELECT `sid` FROM()

并且给from的结果集取上别名,就不会报错

*/

4.HAVING进行分组的应用

/*4.查询有两门以上课程不及格的学生学号及其平均成绩。*/

SELECT  s.sid, AVG(sc.score)

FROM `student` AS s, `score` AS sc

WHERE s.sid IN

(

SELECT `sid` FROM `score`

WHERE `score` < 60

GROUP BY `sid`

HAVING COUNT(`cid`)>= 2

)

AND s.sid=sc.sid

GROUP BY s.sid

/*用到了having 分组*/

5.创建视图

/*5.创建视图student_view,用于查询所有学生的学号、姓名、参加考试课程数、各科总成绩。*/

CREATE VIEW `student_view`

AS

SELECT s.sid,s.stuName,COUNT(c.cid),SUM(sc.score) FROM `student`AS s

INNER JOIN `score` AS sc ON sc.sid=s.sid

INNER JOIN `course` AS c ON c.cid = sc.cid

GROUP BY s.sid;

原文:http://www.cnblogs.com/zeussbook/p/7672261.html

mysql不支持not int查询结果,第九章 MySQL中LIMIT和NOT IN案例相关推荐

  1. 第九章 Mysql语言

    #[例9.1] 使用RAND()函数求3个随机值. #[例9.2] 求3和4的平方根. #[例9.3] 求7.2和-7.2的绝对值. #[例9.4] 求小于或等于-3.5或6.8的最大整数,大于或等于 ...

  2. mysql 按照in id顺序_Mysql查询结果顺序按in()中ID的顺序排列的案例区分

    软件安装:装机软件必备包 SQL是Structured Query Language(结构化查询语言)的缩写.SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言.在使用它时,只需要发出& ...

  3. MYSQL数据库实验三多表查询_数据库之 MySQL --- 数据处理 之多表查询 (三)

    一.多表查询 [1]什么是多表查询? 即,从多个表中获取数据. 注意: 在多表查询是,如果列明在两个表中都有,那么列名前需要加上表名 sql优化:列名前最好加上表名,尤其在多表查询时 SELECT e ...

  4. 在实际使用中 mysql所支持的触发器有_2016计算机二级MySQL冲刺题及答案

    2016计算机二级MySQL冲刺题及答案 11[简答题] 请使用UPDATE语句将数据库db_test的表content中留言人姓名为"MySQL初学者"的留言内容修改为" ...

  5. mysql覆盖索引解决模糊查询失效_关于MySQL的SQL优化之覆盖索引

    前些天,有个同事跟我说:"我写了个SQL,SQL很简单,但是查询速度很慢,并且针对查询条件创建了索引,然而索引却不起作用,你帮我看看有没有办法优化?". 我对他提供的case进行了 ...

  6. mysql索引和数据完整性答案_第5章MySQL索引与完整性约束.ppt

    第5章MySQL索引与完整性约束 5.3.4 CHECK完整性约束 CHECK完整性约束在创建表的时候定义.可以定义为列完整性约束,也可定义为表完整性约束. 语法格式: CHECK(expr) [例5 ...

  7. 《MySQL 8.0 参考手册》第 14 章 MySQL 数据字典

    文章目录 14.1 数据字典模式 数据字典升级过程 使用 MySQL 调试版本查看数据字典表 14.2 删除基于文件的元数据 14.3 事务型数据字典 14.4 数据字典缓存 14.5 INFORMA ...

  8. 深入理解Java虚拟机(第二版) 第九章:类加载及执行子系统的案例与实战

    第九章 类加载及执行子系统的案例与实战 9.1 概述 9.2 Tomcat: 正统的类加载器架构 9.3 OSGi:灵活的类加载器架构 9.4 字节码生成技术与动态代理的实现 9.5 Retrotra ...

  9. 慕课软件质量保证与测试(第九章.程序中隐藏错误数量估计)

    慕课金陵科技学院.软件质量保证与测试.第九章.软件质量与质量保证.程序中隐藏错误数量估计 0 目录 9 软件质量与质量保证 9.2 程序中隐藏错误数量估计 9.2.1 课堂重点 9.2.2 测试与作业 ...

最新文章

  1. boolean类型_JS核心理论之《数据类型、类型转换、深浅拷贝与参数传递》
  2. 微信语音麦克风静音_微信聊天打字慢?教你一分钟打出200个字,父母老人都需要...
  3. php的两种复合数据类型是什么意思_2.4PHP复合数据类型:数组和对象
  4. 将下图的nfa确定化为dfa_想要确定一个宝石矿物种,必须要确定这两大因素
  5. 未封装的扩展程序是什么意思_“冰壶见底未为清,少年如玉有诗名”这句诗是什么意思?...
  6. C语言复习---获取矩阵的对角和
  7. 证书激励法——VBA课程第二次讨论2007年12月6日
  8. unity打开摄像头
  9. [代码]POJ 2409 Let it Bead
  10. MTK移植大全(参考)建议收藏!
  11. js计算文件MD5值
  12. virtuoso 安装与使用
  13. 干货 : 揭秘信息可视化图表的设计方法
  14. 再获认可!人大金仓金融信创优秀解决方案推进我国数字金融高质量发展
  15. 无线通信基础知识3:电磁波的传播
  16. 八大口碑速溶咖啡品牌盘点
  17. WEB开发技术蓝墨云第一次作业
  18. 介绍ReLU6!计算机视觉实习面经(京东/商汤/思谋/依图/图森/字节/腾讯)
  19. SQLServer数据库注入-墨者学院(SQL手工注入漏洞测试(Sql Server数据库))
  20. 6种最流行的项目管理方法

热门文章

  1. CFile::GetStatus
  2. 【 实测可用 】自己做多媒体键盘
  3. css hover遮罩层效果
  4. java arrayadapter_Android之ArrayAdapter详解
  5. Java动态编程之Instrumentation
  6. 西交计算机学保研名单,西安交大保研情况统计表,多专业未满
  7. 与时代共进,酷开科技大屏购物的“钱”途
  8. 爬虫进阶:反反爬虫技巧
  9. Spring系列13:Resource接口及内置实现
  10. 经济学家系列之经济危机