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学习-基础练习题的更多相关文章

  1. MySQL学习基础 之 起航篇

    MySQL 学习来自慕课网<与MySQL的零距离接触> MySQL是一个开源的关系型数据库管理系统 MySQL分为社区版和企业版 MySQL登录和退出相关的命令 参数 描述 -D,--da ...

  2. MySQL学习基础

    MySQL是被Sun公司收购了,所以也有热咖啡图标,不过MySQL的作者后来又做了一个MariaDB,小海豚图标,也很好用. MySQL学习: <MySQL网络数据库设计与开发>(电子工业 ...

  3. MySQL学习——基础

    本文是MySQL的基础知识. Linux启动MySQL服务命令 : service mysql start Linux关闭MySQL服务命令 : service mysql stop 登录MySQL命 ...

  4. MySQL学习基础知识1

    什么是数据库? 数据库就是存储数据的仓库. 存储方式: 变量 无法永久存储 文件处理,可以永久存储,弊端:文件只能在自己的计算机读写,无法被分享(局域网除外) 数据库分类: 1.关系型数据库 提供某种 ...

  5. MySQL学习基础知识2

    1.基础语句 查 select(* | 字段名 | 四则运算 | 聚合函数) from 表名称; 加上as取别名 as可省略 如:select name, (math+english)/2 total ...

  6. Mysql学习---基础操作学习2

    基本数据类型 Mysql基本数据类型:二进制,数值[整数,小数].字符串[定长,变长]. 二进制数据.时间和枚举集合 bit[(M)] 二进制位(101001),m表示二进制位的长度(1-64),默认 ...

  7. Mysql学习基础语法

    -- Mysql 数 据 库 语 法 创建数据库 create database 数据库名; 创建表 ) ); 复制表和数据 create table 复制后新的表名 select * from 旧表 ...

  8. mysql学习基础知识3

    1.视图 简化sql语句的编写,限制可以查看的数据 一张虚拟的表,不占任何内存,查视图时都是临时从所查的表中拿数据 特点: 对于视图的增删改查 都会同步到原始表 对原始表的修改,会同步到视图内可查看的 ...

  9. Mysql学习---基础操作学习

    1.1. 基本操作 数据库引擎 Inodb:支持事务[原子性操作,完成一些列操作后才算完成操作,否则rollback] MyISAM: 支持全文索引,强调了快速读取操作,主要用于高负载的select ...

随机推荐

  1. centos7.2 my.cnf 更改问题

    MySQL与Python交互,踩坑无数,碰到最棘手的问题就是更改:my.cnf文件,记录下来! 安装虚拟机,碰到下载的镜像文件有缺失,一开始没注意,浪费了很多时间.重新下载,安装成功. 安装MySQL ...

  2. Elasticsearch:hanlp 中文分词器

    HanLP 中文分词器是一个开源的分词器,是专为Elasticsearch而设计的.它是基于HanLP,并提供了HanLP中大部分的分词方式.它的源码位于: https://github.com/Ke ...

  3. Spring的概述

    1 Spring是什么? Spring是分层的Java SE/EE应用的full-stack的轻量级开源框架,以IOC(控制反转)和AOP(面向切面编程)为内核,提供了展现层SpringMVC和持久层 ...

  4. python爬虫及结巴分词《攀登者》影评分析

    <攀登者>影评爬取及分析 0.项目结构 其中simkai.ttf为字体文件,Windows查看系统自带的字体 C:\Windows\Fonts 一.爬取豆瓣影评数据 # -*- codin ...

  5. netty之IO演进之路

    常见IO类型: 传统的同步阻塞I/O编程<BIO> 基于NIO的非阻塞编程 基于NIO2.0的异步非阻塞AIO编程 BIO缺点: 没有数据缓冲区,I/O性能存在问题 没有Channel概念 ...

  6. springboot结合jsp页面详解

    第一次写博客,其实就是为了约束我自己,写的不一定对,互相借鉴吧!有不对的地方请多多指正,谢谢! 今天我们来看一下springboot结合jsp页面的具体操作: 1.首先我们先看一下目录结构 由上面我们 ...

  7. 11. ClustrixDB 管理文件空间和数据库容量

    ClustrixDB监视集群中可用的空间量,并主动警告潜在的容量问题.确定集群容量的阈值是可配置的,如下所述. 存储类型 要了解如何管理设备和数据库的利用率,必须首先了解ClustrixDB如何分配磁 ...

  8. mvn 本地jar包 加入自己的maven仓库

    -Dfile :你的jar的名称 -DgroupId :在pom中的groupId -DartifactId :在pom中的artifactId -Dversion :在pom中的version 在j ...

  9. html address标签 语法

    html address标签 语法 作用:定义文档作者/所有者的联系信息. 说明:如果 <address> 元素位于 <body> 元素内部,则它表示该文档作者/所有者的联系信 ...

  10. new 做了什么

    var a=function(){ this.che1 = function () { console.log(1) } this.che2 = function () { console.log(2 ...