MYSQL第四次作业--多表查询

2024-01-17 06:12

本文主要是介绍MYSQL第四次作业--多表查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

二、多表查询

1.创建student和score表

创建student表

创建score表。

CREATE TABLE score (
id INT(10) NOT NULL UNIQUE PRIMARY KEY AUTO_INCREMENT ,
stu_id INT(10) NOT NULL ,
c_name VARCHAR(20) ,
grade INT(10)
);

2.为student表和score表增加记录

向student表插入记录的INSERT语句如下:

INSERT INTO student VALUES( 901,'张老大', '男',1985,'计算机系', '北京市海淀区');
INSERT INTO student VALUES( 902,'张老二', '男',1986,'中文系', '北京市昌平区');
INSERT INTO student VALUES( 903,'张三', '女',1990,'中文系', '湖南省永州市');
INSERT INTO student VALUES( 904,'李四', '男',1990,'英语系', '辽宁省阜新市');
INSERT INTO student VALUES( 905,'王五', '女',1991,'英语系', '福建省厦门市');
INSERT INTO student VALUES( 906,'王六', '男',1988,'计算机系', '湖南省衡阳市');

向score表插入记录的INSERT语句如下:

INSERT INTO score VALUES(NULL,901, '计算机',98);
INSERT INTO score VALUES(NULL,901, '英语', 80);
INSERT INTO score VALUES(NULL,902, '计算机',65);
INSERT INTO score VALUES(NULL,902, '中文',88);
INSERT INTO score VALUES(NULL,903, '中文',95);
INSERT INTO score VALUES(NULL,904, '计算机',70);
INSERT INTO score VALUES(NULL,904, '英语',92);
INSERT INTO score VALUES(NULL,905, '英语',94);
INSERT INTO score VALUES(NULL,906, '计算机',90);
INSERT INTO score VALUES(NULL,906, '英语',85);

3.查询student表的所有记录

mysql> select * from student;
+-----+-----------+------+-------+--------------+--------------------+
| id  | name      | sex  | birth | department   | address            |
+-----+-----------+------+-------+--------------+--------------------+
| 901 | 张老大    | 男   |  1985 | 计算机系     | 北京市海淀区       |
| 902 | 张老二    | 男   |  1986 | 中文系       | 北京市昌平区       |
| 903 | 张三      | 女   |  1990 | 中文系       | 湖南省永州市       |
| 904 | 李四      | 男   |  1990 | 英语系       | 辽宁省阜新市       |
| 905 | 王五      | 女   |  1991 | 英语系       | 福建省厦门市       |
| 906 | 王六      | 男   |  1988 | 计算机系     | 湖南省衡阳市       |
+-----+-----------+------+-------+--------------+--------------------+
6 rows in set (0.00 sec)

4.查询student表的第2条到4条记录

mysql> select * from student limit 1,3;
+-----+-----------+------+-------+------------+--------------------+
| id  | name      | sex  | birth | department | address            |
+-----+-----------+------+-------+------------+--------------------+
| 902 | 张老二    | 男   |  1986 | 中文系     | 北京市昌平区       |
| 903 | 张三      | 女   |  1990 | 中文系     | 湖南省永州市       |
| 904 | 李四      | 男   |  1990 | 英语系     | 辽宁省阜新市       |
+-----+-----------+------+-------+------------+--------------------+
3 rows in set (0.00 sec)

5.从student表查询所有学生的学号(id)、姓名(name)和院系(department)的信息

mysql> select id, name,department from student;
+-----+-----------+--------------+
| id  | name      | department   |
+-----+-----------+--------------+
| 901 | 张老大    | 计算机系     |
| 902 | 张老二    | 中文系       |
| 903 | 张三      | 中文系       |
| 904 | 李四      | 英语系       |
| 905 | 王五      | 英语系       |
| 906 | 王六      | 计算机系     |
+-----+-----------+--------------+
6 rows in set (0.00 sec)

6.从student表中查询计算机系和英语系的学生的信息

mysql> select * from student where department in  ('计算机系','英语系');
+-----+-----------+------+-------+--------------+--------------------+
| id  | name      | sex  | birth | department   | address            |
+-----+-----------+------+-------+--------------+--------------------+
| 901 | 张老大    | 男   |  1985 | 计算机系     | 北京市海淀区       |
| 904 | 李四      | 男   |  1990 | 英语系       | 辽宁省阜新市       |
| 905 | 王五      | 女   |  1991 | 英语系       | 福建省厦门市       |
| 906 | 王六      | 男   |  1988 | 计算机系     | 湖南省衡阳市       |
+-----+-----------+------+-------+--------------+--------------------+
4 rows in set (0.00 sec)mysql> select * from student where department ='计算机系' or department='英语系';
+-----+-----------+------+-------+--------------+--------------------+
| id  | name      | sex  | birth | department   | address            |
+-----+-----------+------+-------+--------------+--------------------+
| 901 | 张老大    | 男   |  1985 | 计算机系     | 北京市海淀区       |
| 904 | 李四      | 男   |  1990 | 英语系       | 辽宁省阜新市       |
| 905 | 王五      | 女   |  1991 | 英语系       | 福建省厦门市       |
| 906 | 王六      | 男   |  1988 | 计算机系     | 湖南省衡阳市       |
+-----+-----------+------+-------+--------------+--------------------+
4 rows in set (0.00 sec)

7.从student表中查询年龄18~22岁的学生信息

mysql> select * from student where 2023-birth between 18 and 20;
Empty set (0.00 sec)

8.从student表中查询每个院系有多少人

mysql> select department,count(*) as '总人数' from student group by department;
+--------------+-----------+
| department   | 总人数    |
+--------------+-----------+
| 计算机系     |         2 |
| 中文系       |         2 |
| 英语系       |         2 |
+--------------+-----------+
3 rows in set (0.00 sec)

9.从score表中查询每个科目的最高分

mysql> select c_name,  max(grade) as '最高分' from score group by c_name;
+-----------+-----------+
| c_name    | 最高分    |
+-----------+-----------+
| 计算机    |        98 |
| 英语      |        94 |
| 中文      |        95 |
+-----------+-----------+
3 rows in set (0.00 sec)

10.查询李四的考试科目(c_name)和考试成绩(grade)

mysql> select c_name '考试科目',grade '考试成绩' from score join student on score.stu_id=student.id where name='李四';
+--------------+--------------+
| 考试科目     | 考试成绩     |
+--------------+--------------+
| 计算机       |           70 |
| 英语         |           92 |
+--------------+--------------+
2 rows in set (0.00 sec)


11.用连接的方式查询所有学生的信息和考试信息

mysql> select c_name ,avg(grang) from score group by c_name;
ERROR 1054 (42S22): Unknown column 'grang' in 'field list'
mysql> select c_name ,avg(grade) from score group by c_name;
+-----------+------------+
| c_name    | avg(grade) |
+-----------+------------+
| 计算机    |    80.7500 |
| 英语      |    87.7500 |
| 中文      |    91.5000 |
+-----------+------------+
3 rows in set (0.00 sec)


12.计算每个学生的总成绩

mysql> select name, stu_id,sum(grade) from score inner join student on score.stu_id=student.id group by stu_id;
+-----------+--------+------------+
| name      | stu_id | sum(grade) |
+-----------+--------+------------+
| 张老大    |    901 |        178 |
| 张老二    |    902 |        153 |
| 张三      |    903 |         95 |
| 李四      |    904 |        162 |
| 王五      |    905 |         94 |
| 王六      |    906 |        175 |
+-----------+--------+------------+
6 rows in set (0.00 sec)


13.计算每个考试科目的平均成绩

mysql> select c_name, avg(grabe) as '平均成绩' from score group by c_name;
ERROR 1054 (42S22): Unknown column 'grabe' in 'field list'
mysql> select c_name, avg(grade) as '平均成绩' from score group by c_name;
+-----------+--------------+
| c_name    | 平均成绩     |
+-----------+--------------+
| 计算机    |      80.7500 |
| 英语      |      87.7500 |
| 中文      |      91.5000 |
+-----------+--------------+
3 rows in set (0.00 sec)


14.查询计算机成绩低于95的学生信息

mysql> select * from student inner join score on  student.id=score.stu_id where c_name = '计算机'
+-----+-----------+------+-------+--------------+--------------------+----+--------+-----------+-
| id  | name      | sex  | birth | department   | address            | id | stu_id | c_name    | 
+-----+-----------+------+-------+--------------+--------------------+----+--------+-----------+-
| 902 | 张老二    | 男   |  1986 | 中文系       | 北京市昌平区       |  3 |    902 | 计算机    | 
| 904 | 李四      | 男   |  1990 | 英语系       | 辽宁省阜新市       |  6 |    904 | 计算机    | 
| 906 | 王六      | 男   |  1988 | 计算机系     | 湖南省衡阳市       |  9 |    906 | 计算机    | 
+-----+-----------+------+-------+--------------+--------------------+----+--------+-----------+-
3 rows in set (0.00 sec)

15.查询同时参加计算机和英语考试的学生的信息

mysql> select * from student where id in ( select stu_id  from score where c_name = '英语' and stu_id in (select stu_id from score where c_name = '计算机'));
+-----+-----------+------+-------+--------------+--------------------+
| id  | name      | sex  | birth | department   | address            |
+-----+-----------+------+-------+--------------+--------------------+
| 901 | 张老大    | 男   |  1985 | 计算机系     | 北京市海淀区       |
| 904 | 李四      | 男   |  1990 | 英语系       | 辽宁省阜新市       |
| 906 | 王六      | 男   |  1988 | 计算机系     | 湖南省衡阳市       |
+-----+-----------+------+-------+--------------+--------------------+
3 rows in set (0.00 sec)

16.将计算机考试成绩按从高到低进行排序
 

mysql> select grade as '计算机成绩' from score where c_name = '计算机' order by grade  desc;
+-----------------+
| 计算机成绩      |
+-----------------+
|              98 |
|              90 |
|              70 |
|              65 |
+-----------------+
4 rows in set (0.00 sec)

17.从student表和score表中查询出学生的学号,然后合并查询结果
 

mysql> select * from student inner join score on student.id=score.stu_id ;
+-----+-----------+------+-------+--------------+--------------------+----+--------+-----------+-
| id  | name      | sex  | birth | department   | address            | id | stu_id | c_name    | 
+-----+-----------+------+-------+--------------+--------------------+----+--------+-----------+-
| 901 | 张老大    | 男   |  1985 | 计算机系     | 北京市海淀区       |  1 |    901 | 计算机    | 
| 901 | 张老大    | 男   |  1985 | 计算机系     | 北京市海淀区       |  2 |    901 | 英语      | 
| 902 | 张老二    | 男   |  1986 | 中文系       | 北京市昌平区       |  3 |    902 | 计算机    | 
| 902 | 张老二    | 男   |  1986 | 中文系       | 北京市昌平区       |  4 |    902 | 中文      | 
| 903 | 张三      | 女   |  1990 | 中文系       | 湖南省永州市       |  5 |    903 | 中文      | 
| 904 | 李四      | 男   |  1990 | 英语系       | 辽宁省阜新市       |  6 |    904 | 计算机    | 
| 904 | 李四      | 男   |  1990 | 英语系       | 辽宁省阜新市       |  7 |    904 | 英语      | 
| 905 | 王五      | 女   |  1991 | 英语系       | 福建省厦门市       |  8 |    905 | 英语      | 
| 906 | 王六      | 男   |  1988 | 计算机系     | 湖南省衡阳市       |  9 |    906 | 计算机    | 
| 906 | 王六      | 男   |  1988 | 计算机系     | 湖南省衡阳市       | 10 |    906 | 英语      | 
+-----+-----------+------+-------+--------------+--------------------+----+--------+-----------+-
10 rows in set (0.00 sec)

18.查询姓张或者姓王的同学的姓名、院系和考试科目及成绩

mysql> select name,c_name,grade from student inner join score on student.id=score.stu_id where name like '张%' or name like '李%';
+-----------+-----------+-------+
| name      | c_name    | grade |
+-----------+-----------+-------+
| 张老大    | 计算机    |    98 |
| 张老大    | 英语      |    80 |
| 张老二    | 计算机    |    65 |
| 张老二    | 中文      |    88 |
| 张三      | 中文      |    95 |
| 李四      | 计算机    |    70 |
| 李四      | 英语      |    92 |
+-----------+-----------+-------+
7 rows in set (0.00 sec)

19.查询都是湖南的学生的姓名、年龄、院系和考试科目及成绩

mysql> select name,2024-birth,department,address,c_name,grade from student inner join score on sttudent.id=score.stu_id where address like  '湖南%' ;
+--------+------------+--------------+--------------------+-----------+-------+
| name   | 2024-birth | department   | address            | c_name    | grade |
+--------+------------+--------------+--------------------+-----------+-------+
| 张三   |         34 | 中文系       | 湖南省永州市       | 中文      |    95 |
| 王六   |         36 | 计算机系     | 湖南省衡阳市       | 计算机    |    90 |
| 王六   |         36 | 计算机系     | 湖南省衡阳市       | 英语      |    85 |
+--------+------------+--------------+--------------------+-----------+-------+
3 rows in set (0.00 sec)

 

这篇关于MYSQL第四次作业--多表查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/615088

相关文章

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

mysql重置root密码的完整步骤(适用于5.7和8.0)

《mysql重置root密码的完整步骤(适用于5.7和8.0)》:本文主要介绍mysql重置root密码的完整步骤,文中描述了如何停止MySQL服务、以管理员身份打开命令行、替换配置文件路径、修改... 目录第一步:先停止mysql服务,一定要停止!方式一:通过命令行关闭mysql服务方式二:通过服务项关闭

SQL Server数据库磁盘满了的解决办法

《SQLServer数据库磁盘满了的解决办法》系统再正常运行,我还在操作中,突然发现接口报错,后续所有接口都报错了,一查日志发现说是数据库磁盘满了,所以本文记录了SQLServer数据库磁盘满了的解... 目录问题解决方法删除数据库日志设置数据库日志大小问题今http://www.chinasem.cn天发

mysql主从及遇到的问题解决

《mysql主从及遇到的问题解决》本文详细介绍了如何使用Docker配置MySQL主从复制,首先创建了两个文件夹并分别配置了`my.cnf`文件,通过执行脚本启动容器并配置好主从关系,文中还提到了一些... 目录mysql主从及遇到问题解决遇到的问题说明总结mysql主从及遇到问题解决1.基于mysql

MySQL的索引失效的原因实例及解决方案

《MySQL的索引失效的原因实例及解决方案》这篇文章主要讨论了MySQL索引失效的常见原因及其解决方案,它涵盖了数据类型不匹配、隐式转换、函数或表达式、范围查询、LIKE查询、OR条件、全表扫描、索引... 目录1. 数据类型不匹配2. 隐式转换3. 函数或表达式4. 范围查询之后的列5. like 查询6

Redis KEYS查询大批量数据替代方案

《RedisKEYS查询大批量数据替代方案》在使用Redis时,KEYS命令虽然简单直接,但其全表扫描的特性在处理大规模数据时会导致性能问题,甚至可能阻塞Redis服务,本文将介绍SCAN命令、有序... 目录前言KEYS命令问题背景替代方案1.使用 SCAN 命令2. 使用有序集合(Sorted Set)

Linux下MySQL8.0.26安装教程

《Linux下MySQL8.0.26安装教程》文章详细介绍了如何在Linux系统上安装和配置MySQL,包括下载、解压、安装依赖、启动服务、获取默认密码、设置密码、支持远程登录以及创建表,感兴趣的朋友... 目录1.找到官网下载位置1.访问mysql存档2.下载社区版3.百度网盘中2.linux安装配置1.

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

PostgreSQL如何用psql运行SQL文件

《PostgreSQL如何用psql运行SQL文件》文章介绍了两种运行预写好的SQL文件的方式:首先连接数据库后执行,或者直接通过psql命令执行,需要注意的是,文件路径在Linux系统中应使用斜杠/... 目录PostgreSQ编程L用psql运行SQL文件方式一方式二总结PostgreSQL用psql运