第九章 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;

第九章 MySQL中LIMIT和NOT IN案例的更多相关文章

  1. mysql中limit与in不能同时使用的解决方式.

    mysql中limit与in不能同时使用的解决方式. 分类: MySQL2011-10-31 13:53 1277人阅读 评论(0) 收藏 举报 mysqlsubquery MySQL5.1中子查询是 ...

  2. mysql中limit的用法实例解析

    mysql中limit的用法解析. 在mysql中,select * from table limit m,n.其中m是指记录开始的index,从0开始,n是指从第m条开始,取n条. 例如: mysq ...

  3. oracle数据库不支持mysql中limit功能

    oracle数据库不支持mysql中limit功能,但可以通过rownum来限制返回的结果集的行数,rownum并不是用户添加的字段,而是oracle系统自动添加的. (1)使查询结果最多返回前10行 ...

  4. (转载)mysql中limit用法

    (转载)http://hi.baidu.com/sppeivan/item/e45179375d6778c62f8ec221   mysql中limit用法 使用查询语句的时候,经常要返回前几条或者中 ...

  5. Mysql中limit的用法详解

    Mysql中limit的用法详解 在我们使用查询语句的时候,经常要返回前几条或者中间某几行数据,为我们提供了limit这样一个功能. SELECT * FROM table LIMIT [offset ...

  6. mysql中limit用法误区

    之前一直用oracle,在分页的时候用rownumber,转换到mysql上之后,用limit做分页: 在做某个业务的时候,需要先将数据排序,再分页,在给limit上参数的时候沿用了oracle的ro ...

  7. MYSQL 中 LIMIT 用法

    mapper文件中的sql: ------------------------------------------------------------------------------------- ...

  8. 【开发笔记】- MySQL中limit查询超级慢,怎么办?

    有如下解决方法: (1).通过判断id的范围来分页 limit ; 也得到了分页的数据,但是我们发现如果id不是顺序的,也就是如果有数据删除过的话,那么这样分页数据就会不正确,这个是有缺陷的. (2) ...

  9. MySQL 中LIMIT的使用详解

    在使用数据库过程中,常会遇到查询或者导出某个数据表或者查询集的前几条或者后几条记录,LIMIT可以很好的满足需求. LIMIT基本语法: 如果只给定一个参数,表示记录数. mysql; ) 相当于 m ...

随机推荐

  1. 前端AES的加密和解密

    在工作的过程中,经常要对一些数据做一些加密,当然有复杂的加密和简单的加密,也有对称加密等等.总之加密的方式有很多.今天在这里,我只是简单的分享一个我最近遇到的加密方式-AES.这个也是后端工程师用的, ...

  2. 【★】IT界8大恐怖预言

    IT界的8大恐怖预言 本文字数:3276 建议阅读时间:你开心就好 第三次科技革命已经进入白热化阶段---信息技术革命作为其中最主要的一环已经奠定了其基本格局和趋势.OK大势已定,根据目前的形势,小编 ...

  3. 201521123114 《Java程序设计》第8周学习总结

    1. 本章学习总结 2. 书面作业 Q1. List中指定元素的删除(题目4-1) 1.1 实验总结 使用iterator迭代器的remove()函数来移除元素,能够从最后一个元素来移除,可以避免从第 ...

  4. Java课程设计+购物车WEB页面

    1. 团队名称(keke) 徐婉萍:网络1511 201521123006 2. 项目git地址 3. 项目git提交记录截图 4. 项目功能架构图与主要功能流程图 项目功能架构图 项目主要功能流程图 ...

  5. 201521123015 《Java程序设计》第12周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多流与文件相关内容. 2. 书面作业 将Student对象(属性:int id, String name,int age,doubl ...

  6. 升级Linux tar &&解决某用tar解压失败的tar包

    今天解压个文件,出来很多这样的: /bin/tar: Ignoring unknown extended header keyword `SCHILY.dev'/bin/tar: Ignoring u ...

  7. [js高手之路]Node.js+jade+express+mongodb+mongoose+promise实现todolist

    promise主要是用来解决异步回调问题,其实还有好几种比promise更好的方案,后面再说,这节,我们先用promise来改造下,我以前写的一篇文章[js高手之路]javascript腾讯面试题学习 ...

  8. MyBatis学习(四)XML配置文件之SQL映射的XML文件

    SQL映射文件常用的元素: 1.select 查询语句是MyBatis最常用的语句之一. 执行简单查询的select元素是非常简单的: <select id="selectUser&q ...

  9. spring boot基础 入门

    spring boot基础 spring boot 的简单搭建 spring boot 的基本用法 spring boot 基本用法 自动配置 技术集成 性能监控 源码解析 工程的构建 创建一个mav ...

  10. servlet_2

    package com.atguigu.servlet; import java.io.IOException; import javax.servlet.Servlet;import javax.s ...