MySQL学习-基础练习题
day1
学生表操作:
1. 查询出班级205有多少个男生
2. 查询出名字为4个字的所有学生信息(编号、姓名,年龄,班级)
3. 查询出所有姓王的学生信息(编号、姓名,年龄,班级)
4. 查询出班级编号为201,202,203的女生总人数
5. 查询出学号整十的所有女生信息(姓名、年龄、个人简介)
6. 删除301班级中年龄在23岁以上的学生信息
7. 把一个叫'卫然'的学生的姓别改成女的
8. 把401班级中的姓名为'吴杰'的学生信息删除
9. 计算305班中所有学生的平均年龄以及他们的最大年龄和最小年龄
10. 查询401,402,403,404,405中所有学生的年龄平均值
11. 查询出所有学生中"白"的学生信息,并对他们使用年龄进行升序排列
12. 添加以下学生记录到数据表中
姓名 年龄 性别 班级 个性签名
张三丰 22 1 301 我是武当老板
张翠山 21 1 302 我是武当老板的五弟子
张无忌 20 1 302 明教老板
13. 查询年龄在18-20之间的姓李的女生
14. 查询年龄在18-20之间的所有女生,并按照编号进行降序排序
15. 查询出301,302,303,304,305,306中每个班级总人数。
成绩表操作
16. 查询出学号为9的学生的总成绩
17. 查询出课程编号为4的课程平均成绩
18. 查询出学号为6的学生的所有成绩,并显示对应的课程编号。
19. 查询出课程编号为20的课程成绩,并进行分数的降序排列,显示10个成绩即可。
20. 查询出学号为1,2,3,4,5,6这几个学员的平均成绩。
21. 查询出证成绩表中每个学科的平均成绩。
day2
python操作数据库
1. 查询student表的所有记录
2. 查询student表的第2条到第4条记录
3. 查询所有学生的学号(id)、姓名(name)和报读课程(department)的信息
4. 删除305班年龄最小的学生
5. 修改id为66的学员的姓名为男
SQL语句编写
1. 查询Django课程和Django项目的所有学生的信息[学号,姓名,年龄,成绩]
mysql> select a.id,name,age,achievement
-> from student as a
-> left join achievement as b
-> on a.id = b.sid
-> left join course as c
-> on b.cid = c.id
-> where c.course like 'Django%';
2. 查询id=5的老师的所有学生信息[学号、姓名、年龄]
mysql> select a.id,a.name,a.age
-> from student as a
-> left join achievement as b
-> on a.id = b.sid
-> left join course as c
-> on b.cid = c.id
-> left join lecturer as d
-> on c.lecturer_id = d.id
-> where d.id =5;
3. 查询306班、307、308班中成绩及格的学生
mysql> select a.name,a.age,a.sex,c.course,b.achievement
-> from student as a
-> left join achievement as b
-> on a.id= b.sid
-> left join course as c
-> on b.cid = c.id
-> where a.class in (306,307,308) and b.achievement >=60;
4. 查询python成绩及格的所有学生信息[学号、姓名、年龄、班级]
mysql> select a.id,a.name,a.age,a.class,b.achievement
-> from student as a
-> left join achievement as b
-> on a.id = b.sid
-> left join course as c
-> on b.cid = c.id
-> where c.course='python' and b.achievement >=60;
5. 查出所有女生的平均成绩和报读课程。
mysql> select c.course,avg(b.achievement)
-> from student as a
-> left join achievement as b
-> on a.id = b.sid
-> left join course as c
-> on b.cid = c.id
-> where a.sex =2 group by c.course;
6. 查询出女生人数最多的5个课程。
mysql>select c.course,c.id,count(a.id)
-> from student as a
-> left join achievement as b
-> on a.id = b.sid
-> left join course as c
-> on b.cid = c.id
-> where a.sex =2 group by c.course order by count(a.id) desc, c.id asc limit 5;
7. 查询出报读flask课程的学生中女生的数量
mysql> select count(a.id)
-> from student as a
-> left join achievement as b
-> on a.id = b.sid
-> left join course as c
-> on b.cid = c.id
-> where c.course ='flask' and a.sex =2;
8. 查询出 赵华 报读的课程信息[ 上课老师名字,课程分数,平均分 ]
mysql> select d.name,c.course,b.achievement,avg(b.achievement)
-> from student as a
-> left join achievement as b
-> on a.id = b.sid
-> left join course as c
-> on b.cid = c.id
-> left join lecturer as d
-> on c.lecturer_id = d.id
-> where a.name = '赵华' group by c.course;
9.查出 401 班所有学生的 平均分和总分[分组查询]。
mysql> select c.course,avg(b.achievement),sum(b.achievement)
-> from student as a
-> left join achievement as b
-> on a.id= b.sid
-> left join course as c
-> on b.cid = c.id
-> where a.class=401 group by c.course;
10.查出报读了flask、django课程中年龄在21到23岁之间的所有男生的成绩
mysql> select c.course,avg(b.achievement)
-> from student as a
-> left join achievement as b
-> on a.id = b.sid
-> left join course as c
-> on b.cid = c.id
-> where c.course in ('flask','django') and a.age between 21 and 23 group by c.course;
11.查处总分在200分以上的所有学生的姓名、班级
select a.class,a.name,sum(b.achievement)
from student as a
left join achievement as b
on a.id = b.sid
group by a.id having sum(b.achievement)>200 order by sum(b.achievement) desc ;
ok
MySQL学习-基础练习题的更多相关文章
- MySQL学习基础 之 起航篇
MySQL 学习来自慕课网<与MySQL的零距离接触> MySQL是一个开源的关系型数据库管理系统 MySQL分为社区版和企业版 MySQL登录和退出相关的命令 参数 描述 -D,--da ...
- MySQL学习基础
MySQL是被Sun公司收购了,所以也有热咖啡图标,不过MySQL的作者后来又做了一个MariaDB,小海豚图标,也很好用. MySQL学习: <MySQL网络数据库设计与开发>(电子工业 ...
- MySQL学习——基础
本文是MySQL的基础知识. Linux启动MySQL服务命令 : service mysql start Linux关闭MySQL服务命令 : service mysql stop 登录MySQL命 ...
- MySQL学习基础知识1
什么是数据库? 数据库就是存储数据的仓库. 存储方式: 变量 无法永久存储 文件处理,可以永久存储,弊端:文件只能在自己的计算机读写,无法被分享(局域网除外) 数据库分类: 1.关系型数据库 提供某种 ...
- MySQL学习基础知识2
1.基础语句 查 select(* | 字段名 | 四则运算 | 聚合函数) from 表名称; 加上as取别名 as可省略 如:select name, (math+english)/2 total ...
- Mysql学习---基础操作学习2
基本数据类型 Mysql基本数据类型:二进制,数值[整数,小数].字符串[定长,变长]. 二进制数据.时间和枚举集合 bit[(M)] 二进制位(101001),m表示二进制位的长度(1-64),默认 ...
- Mysql学习基础语法
-- Mysql 数 据 库 语 法 创建数据库 create database 数据库名; 创建表 ) ); 复制表和数据 create table 复制后新的表名 select * from 旧表 ...
- mysql学习基础知识3
1.视图 简化sql语句的编写,限制可以查看的数据 一张虚拟的表,不占任何内存,查视图时都是临时从所查的表中拿数据 特点: 对于视图的增删改查 都会同步到原始表 对原始表的修改,会同步到视图内可查看的 ...
- Mysql学习---基础操作学习
1.1. 基本操作 数据库引擎 Inodb:支持事务[原子性操作,完成一些列操作后才算完成操作,否则rollback] MyISAM: 支持全文索引,强调了快速读取操作,主要用于高负载的select ...
随机推荐
- zencart产品批量采集伪原创方法,再也不用担心与别人的数据重复了
首先,请你提供与产品相关的关键词一份,至于关键词如何来,相信做SEO的你很清楚了,SEO关键词搜索工具应该很多,比如谷歌相关关键词搜索,用记事本的形式保存为每行一个关键词.采集产品的时候,我会帮你将关 ...
- 隐马尔可夫模型中基于比例因子的前向算法(java实现)
直接上干货哈,其他子算法,后续补上. System.out.print ...
- python如何导入自定义文件和模块全部方法
项目中想使用自定义python文件(本地代码) 有6种方式, 1.这种最简单,也可能最不实用,将你的外部文件放到跟需要调用外部文件的文件同一个包下,同一目录 folder------toinvoke. ...
- uwsgi 的启动、停止、重启
## 一.概念释义### WSGI WSGI 是一个Web服务器(如nginx)与应用服务器(如uWSGI)通信的一种规范(协议).官方定义是,the Python Web Server Gatewa ...
- Docker(四):Docker常用命令
除过以上我们使用的Docker命令外,Docker还有一些其它常用的命令 拉取docker镜像 docker pull image_name 查看宿主机上的镜像,Docker镜像保存在/var/lib ...
- 数据库基本概念及Oracle基本语句
一.数据库分类 通常是按照数据模型的特点将传统数据库系统分成网状数据库.层次数据库和关系数据库三种. 1.网状数据库 顾名思义,网状数据库采用的是以记录类型为结点的网状数据模型,是一种导航式(Navi ...
- 设置HTML的TextArea标记跟随文本内容自动设置高度
写内容的时候用的是textarea来写,可以换行,然后预览页面也要显示是换行才行,所以预览页面还是要用textarea来显示, 样式去掉边框,不可以拉伸,不可编辑 // html <textar ...
- 在vue中结合render函数渲染指定的组件到容器中
1.demo 项目结构: index.html <!DOCTYPE html> <html> <head> <title>标题</title> ...
- SpringBoot2.2发行版新特性
Spring Framework升级 SpringBoot2.2的底层Spring Framework版本升级为5.2. JMX默认禁用 默认情况下不再启用JMX. 可以使用配置属性spring.jm ...
- 【BZOJ3894】 文理分科
Description 文理分科是一件很纠结的事情!(虽然看到这个题目的人肯定都没有纠 结过) 小P所在的班级要进行文理分科.他的班级可以用一个n*m的矩阵进行 描述,每个格子代表一个同学的座位. ...