Mysql练习题(1)
表名和字段
------------------------------------------------------------------------------
–1.学生表
Student(s_id,s_name,s_birth,s_sex) --学生编号,学生姓名, 出生年月,学生性别
–2.课程表
Course(c_id,c_name,t_id) – --课程编号, 课程名称, 教师编号额
–3.教师表
Teacher(t_id,t_name) --教师编号,教师姓名
–4.成绩表
Score(s_id,c_id,s_score) --学生编号,课程编号,分数
测试数据
------------------------------------------------------------------------------
--建表
--学生表
CREATE TABLE `Student`(
	`s_id` VARCHAR(20),
	`s_name` VARCHAR(20) NOT NULL DEFAULT '',
	`s_birth` VARCHAR(20) NOT NULL DEFAULT '',
	`s_sex` VARCHAR(10) NOT NULL DEFAULT '',
	PRIMARY KEY(`s_id`)
);
--课程表
CREATE TABLE `Course`(
	`c_id`  VARCHAR(20),
	`c_name` VARCHAR(20) NOT NULL DEFAULT '',
	`t_id` VARCHAR(20) NOT NULL,
	PRIMARY KEY(`c_id`)
);
--教师表
CREATE TABLE `Teacher`(
	`t_id` VARCHAR(20),
	`t_name` VARCHAR(20) NOT NULL DEFAULT '',
	PRIMARY KEY(`t_id`)
);
--成绩表
CREATE TABLE `Score`(
	`s_id` VARCHAR(20),
	`c_id`  VARCHAR(20),
	`s_score` INT(3),
	PRIMARY KEY(`s_id`,`c_id`)
);
--插入学生表测试数据
insert into Student values('01' , '赵雷' , '1990-01-01' , '男');
insert into Student values('02' , '钱电' , '1990-12-21' , '男');
insert into Student values('03' , '孙风' , '1990-05-20' , '男');
insert into Student values('04' , '李云' , '1990-08-06' , '男');
insert into Student values('05' , '周梅' , '1991-12-01' , '女');
insert into Student values('06' , '吴兰' , '1992-03-01' , '女');
insert into Student values('07' , '郑竹' , '1989-07-01' , '女');
insert into Student values('08' , '王菊' , '1990-01-20' , '女');
--课程表测试数据
insert into Course values('01' , '语文' , '02');
insert into Course values('02' , '数学' , '01');
insert into Course values('03' , '英语' , '03');
--教师表测试数据
insert into Teacher values('01' , '张三');
insert into Teacher values('02' , '李四');
insert into Teacher values('03' , '王五');
--成绩表测试数据
insert into Score values('01' , '01' , 80);
insert into Score values('01' , '02' , 90);
insert into Score values('01' , '03' , 99);
insert into Score values('02' , '01' , 70);
insert into Score values('02' , '02' , 60);
insert into Score values('02' , '03' , 80);
insert into Score values('03' , '01' , 80);
insert into Score values('03' , '02' , 80);
insert into Score values('03' , '03' , 80);
insert into Score values('04' , '01' , 50);
insert into Score values('04' , '02' , 30);
insert into Score values('04' , '03' , 20);
insert into Score values('05' , '01' , 76);
insert into Score values('05' , '02' , 87);
insert into Score values('06' , '01' , 31);
insert into Score values('06' , '03' , 34);
insert into Score values('07' , '02' , 89);
insert into Score values('07' , '03' , 98);
---------------------
练习题
------------------------------------------------------------------------------
-- 1、查询"01"课程比"02"课程成绩高的学生的信息及课程分数	
select
        s1.*,
        s2.01_score,
        s2.02_score
    from
        student s1,
        (
            select t1.s_id as s_id,
            t1.s_score as 01_score,
            t2.s_score as 02_score
        from
            score t1,
            score t2
        where
            t1.s_id = t2.s_id
            and t1.c_id = '01'
            and t2.c_id = '02'
            and t1.s_score > t2.s_score ) s2
    where
        s1.s_id = s2.s_id;
-- 2、查询"01"课程比"02"课程成绩低的学生的信息及课程分数
select
        s1.*,
        s2.01_score,
        s2.02_score
    from
        student s1,
        (
            select t1.s_id as s_id,
            t1.s_score as 01_score,
            t2.s_score as 02_score
        from
            score t1,
            score t2
        where
            t1.s_id = t2.s_id
            and t1.c_id = '01'
            and t2.c_id = '02'
            and t1.s_score < t2.s_score ) s2
    where
        s1.s_id = s2.s_id;		
-- 3、查询平均成绩大于等于60分的同学的学生编号和学生姓名和平均成绩
select
    t1.s_id,
    t2.s_name,
    avg(t1.s_score) as avg_score
from
    score t1
left join student t2 on
    t1.s_id = t2.s_id
group by
    t1.s_id
having
    avg(t1.s_score) >= 60;
-- 4、查询平均成绩小于60分的同学的学生编号和学生姓名和平均成绩
		-- (包括有成绩的和无成绩的)
select
    t1.s_id,
    t2.s_name,
    avg(t1.s_score) as avg_score
from
    score t1
left join student t2 on
    t1.s_id = t2.s_id
group by
    t1.s_id
having
    avg(t1.s_score) < 60;
-- 5、查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩	
select
    t2.s_id,
    t2.s_name,
    count(t1.c_id) as sun_course,
    sum(t1.s_score) as sum_score
from
    student t2
left join score t1 on
    t1.s_id = t2.s_id
group by
    t1.s_id;	
-- 6、查询"李"姓老师的数量 	
select
    count(1)
from
    teacher
where
    t_name like '李%' ;
-- 7、查询学过"张三"老师授课的同学的信息
 select
    t1.*
from
    student t1,
    score t2
where
    t1.s_id = t2.s_id
    and t2.c_id in (
        select c_id
    from
        course
    where
        t_id = (
            select t_id
        from
            teacher
        where
            t_name = '张三'));
-- 8、查询没学过"张三"老师授课的同学的信息 
select
    *
from
    student
where
    s_id not in (
    select
        distinct s_id
    from
        score
    where
        c_id in (
            select t2.c_id
        from
            teacher t1,
            course t2
        where
            t1.t_id = t2.t_id
            and t1.t_name = '张三'));
Mysql练习题(1)的更多相关文章
- MySQL练习题
		MySQL练习题 一.表关系 请创建如下表,并创建相关约束 二.操作表 1.自行创建测试数据 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号: 3.查询平均成绩大于60分的同学的学号和平均成 ... 
- MySQL练习题参考答案
		MySQL练习题参考答案 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号: 思路: 获取所有有生物课程的人(学号,成绩) - 临时表 获取所有有物理课程的人(学号,成绩) - 临时表 根据[ ... 
- s15day12作业:MySQL练习题参考答案
		MySQL练习题参考答案 导出现有数据库数据: mysqldump -u用户名 -p密码 数据库名称 >导出文件路径 # 结构+数据 mysqldump -u用户名 -p ... 
- Python/ MySQL练习题(一)
		Python/ MySQL练习题(一) 查询“生物”课程比“物理”课程成绩高的所有学生的学号 SELECT * FROM ( SELECT * FROM course LEFT JOIN score ... 
- python/MySQL练习题(二)
		python/MySQL练习题(二) 查询各科成绩前三名的记录:(不考虑成绩并列情况) select score.sid,score.course_id,score.num,T.first_num,T ... 
- python 全栈开发,Day65(MySQL练习题,参考答案)
		一.MySQL练习题 一.表关系 请创建如下表,并创建相关约束 二.操作表 1.自行创建测试数据 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号.ps:针对的是自己的生物成绩比物理成绩高,再 ... 
- mysql 练习题答案
		一 题目 1.查询所有的课程的名称以及对应的任课老师姓名 2.查询学生表中男女生各有多少人 3.查询物理成绩等于100的学生的姓名 4.查询平均成绩大于八十分的同学的姓名和平均成绩 5.查询所有学生的 ... 
- mysql练习题练习
		1.数据库是按照原文制作的,表格结构一样具体存储的数据有些差异 原文地址:MySQL练习题 原答案地址:MySQL练习题参考答案 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号: selec ... 
- MySQL练习题及答案(复习)
		新建一个叫做 review 的数据库,将测试数据脚本导进去.(可以使用Navicat查询功能) /* Navicat MySQL Data Transfer Source Server : DB So ... 
- mysql练习题-查询同时参加计算机和英语考试的学生的信息-遁地龙卷风
		(-1)写在前面 文章参考http://blog.sina.com.cn/willcaty. 针对其中的一道练习题想出两种其他的答案,希望网友给出更多回答. (0) 基础数据 student表 +-- ... 
随机推荐
- C# 请求数据 方式1
			public static string PostWebRequest2() { HttpWebRequest req = (HttpWebRequest)HttpWebRequest.Create( ... 
- A@G!C005
			AGC005 A STring 不会,有没有老鸽蕉蕉我/kk/kel/dk https://agc005.contest.atcoder.jp/submissions/7926986 B Minimu ... 
- 如何使用git把本地代码上传到远程仓库上
			初始化 git init 查看当前仓库状态 git status 将项目的文件添加到仓库中 git add test.txt git add -A git add . 将add的文件commit到仓库 ... 
- 内核过DSE驱动签名验证.
			一丶简介 现在的驱动,必须都有签名才能加载.那么如何加载无签名的驱动模块那. 下面可以说下方法.但是挺尴尬的是,代码必须在驱动中编写.所以就形成了 你必须一个驱动带有一个签名加载进去.执行你的代码.p ... 
- mac 安装注册Charles
			软件去官网下载安装即可. 下载地址:https://www.charlesproxy.com/download/ 适用于Charles任意版本的注册码Charles 4.2.7 目前是最新版,可用. ... 
- .NET项目发布到本地IIS完整流程(VS2015)
			概要: 一.安装IIS功能 二.建立发布网站 三.发布应用程序 四.发布后各种问题的解决. [可先看概要四,可避免很多坑] 具体操作: 一.安装IIS功能 选择必要的功能进行安装,重启有效. 二.建立 ... 
- SpringCloud:gateway网关模块启动报错
			1.错误信息 org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with na ... 
- AMPPZ2014 The Captain
			传送门 BZOJdown Solution 比较妙,考虑按照给出的式子,只有\(x\)相邻或者\(y\)相邻的才会走,不然一定会走到相邻的再走\(x\)或\(y\),所以直接排序两边然后最短路即可. ... 
- eureka中显示有服务但是通过ribbon调用显示No instances available for service-hello的问题
			一,问题 采取eureka集群.客户端通过Ribbon调用服务,Ribbon端报下列异常 ? 1 2 3 4 5 6 7 java.net.UnknownHostException: SERVICE- ... 
- [技术博客]Android 开发 Bug Log
			[技术博客] Android 开发 Bug Log 大大小小的bug,聪明的愚蠢的都有, 持续记录中...... java.lang.IllegalArgumentException: The sty ... 
