MySQL多表查询(改进版)

1.创建student和score表

mysql> CREATE  TABLE student (-> id  INT(10)  NOT NULL  UNIQUE  PRIMARY KEY ,-> name  VARCHAR(20)  NOT NULL ,-> sex  VARCHAR(4) ,-> birth  YEAR,-> department  VARCHAR(20) ,-> address  VARCHAR(50)-> );
Query OK, 0 rows affected, 1 warning (0.03 sec)mysql> 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)-> );
Query OK, 0 rows affected, 3 warnings (0.05 sec)

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

mysql> INSERT INTO student VALUES
( 901,'张老大', '男',1985,'计算机系', '北京市海淀区'),
( 902,'张老二', '男',1986,'中文系', '北京市昌平区'),
( 903,'张三', '女',1990,'中文系', '湖南省永州市'),
( 904,'李四', '男',1990,'英语系', '辽宁省阜新市'),
( 905,'王五', '女',1991,'英语系', '福建省厦门市'),
( 906,'王六', '男',1988,'计算机系', '湖南省衡阳市');
Query OK, 6 row affected (0.00 sec)INSERT INTO score VALUES
(NULL,901, '计算机',98),
(NULL,901, '英语', 80),
(NULL,902, '计算机',65),
(NULL,902, '中文',88),
(NULL,903, '中文',95),
(NULL,904, '计算机',70),
(NULL,904, '英语',92),
(NULL,905, '英语',94),
(NULL,906, '计算机',90),
(NULL,906, '英语',85);
Query OK, 10 rows affected (0.03 sec)
Records: 10  Duplicates: 0  Warnings: 0

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 = '计算机系' 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> insert into student values(907,'李九','男','2005','中文系','北京市昌平区');
mysql> select * from student where year(now()) - birth between 18 and 22;
+-----+--------+------+-------+------------+--------------------+
| id  | name   | sex  | birth | department | address            |
+-----+--------+------+-------+------------+--------------------+
| 907 | 李九    ||  2005 | 中文系      | 北京市昌平区       |
+-----+--------+------+-------+------------+--------------------+
1 row in set (0.00 sec)

在这里插入图片描述

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

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

在这里插入图片描述

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

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

在这里插入图片描述

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

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

在这里插入图片描述

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

mysql> select stu.*,s.c_name,s.grade from student stu inner join score s on stu.id=s.stu_id;
+-----+-----------+------+-------+--------------+--------------------+-----------+-------+
| id  | name      | sex  | birth | department   | address            | c_name    | grade |
+-----+-----------+------+-------+--------------+--------------------+-----------+-------+
| 901 | 张老大    ||  1985 | 计算机系     | 北京市海淀区       | 计算机    |    98 |
| 901 | 张老大    ||  1985 | 计算机系     | 北京市海淀区       | 英语      |    80 |
| 902 | 张老二    ||  1986 | 中文系       | 北京市昌平区       | 计算机    |    65 |
| 902 | 张老二    ||  1986 | 中文系       | 北京市昌平区       | 中文      |    88 |
| 903 | 张三      ||  1990 | 中文系       | 湖南省永州市       | 中文      |    95 |
| 904 | 李四      ||  1990 | 英语系       | 辽宁省阜新市       | 计算机    |    70 |
| 904 | 李四      ||  1990 | 英语系       | 辽宁省阜新市       | 英语      |    92 |
| 905 | 王五      ||  1991 | 英语系       | 福建省厦门市       | 英语      |    94 |
| 906 | 王六      ||  1988 | 计算机系     | 湖南省衡阳市       | 计算机    |    90 |
| 906 | 王六      ||  1988 | 计算机系     | 湖南省衡阳市       | 英语      |    85 |
+-----+-----------+------+-------+--------------+--------------------+-----------+-------+
10 rows in set (0.00 sec)

在这里插入图片描述

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

mysql> select name 姓名,sum(grade) 总成绩 from student stu inner join score s on stu.id=s.stu_id group by stu.name;
+-----------+-----------+
| 姓名      | 总成绩    |
+-----------+-----------+
| 张老大    |       178 |
| 张老二    |       153 |
| 张三      |        95 |
| 李四      |       162 |
| 王五      |        94 |
| 王六      |       175 |
+-----------+-----------+
6 rows in set (0.02 sec)

在这里插入图片描述

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

mysql> select c_name 科目,avg(grade) 平均成绩 from score group by c_name;
+-----------+--------------+
| 科目      | 平均成绩     |
+-----------+--------------+
| 计算机    |      80.7500 |
| 英语      |      87.7500 |
| 中文      |      91.5000 |
+-----------+--------------+
3 rows in set (0.00 sec)

在这里插入图片描述

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

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

在这里插入图片描述

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

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

在这里插入图片描述

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

mysql> select name,c_name,grade from student stu inner join score s on stu.id=s.stu_id  where c_name='计算机' order by grade desc;
+-----------+-----------+-------+
| name      | c_name    | grade |
+-----------+-----------+-------+
| 张老大    | 计算机    |    98 |
| 王六      | 计算机    |    90 |
| 李四      | 计算机    |    70 |
| 张老二    | 计算机    |    65 |
+-----------+-----------+-------+
4 rows in set (0.00 sec)

在这里插入图片描述

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

mysql> select student.id from student union select score.stu_id from score;
+-----+
| id  |
+-----+
| 901 |
| 902 |
| 903 |
| 904 |
| 905 |
| 906 |
| 907 |
+-----+
7 rows in set (0.00 sec)

在这里插入图片描述

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

mysql> select name,department,c_name,grade from student stu inner join score s on stu.id=s.stu_id where name regexp '^(张|王)';
+-----------+--------------+-----------+-------+
| name      | department   | c_name    | grade |
+-----------+--------------+-----------+-------+
| 张老大    | 计算机系     | 计算机    |    98 |
| 张老大    | 计算机系     | 英语      |    80 |
| 张老二    | 中文系       | 计算机    |    65 |
| 张老二    | 中文系       | 中文      |    88 |
| 张三      | 中文系       | 中文      |    95 |
| 王五      | 英语系       | 英语      |    94 |
| 王六      | 计算机系     | 计算机    |    90 |
| 王六      | 计算机系     | 英语      |    85 |
+-----------+--------------+-----------+-------+
8 rows in set (0.00 sec)

在这里插入图片描述

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

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

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/625188.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringCloud Nacos服务注册中心和配置中心

一、什么是Nacos&#xff1f; 官方介绍是这样的&#xff1a; Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集&#xff0c;帮助您实现动态服务发现、服务配置管理、服务及流量管理。 Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Na…

Linux中放大字体

环境&#xff1a;VMware17Pro&#xff0c;Ubuntu22.04 在显示设置外观中只看到图标放大的调整&#xff0c;没看到字体大小设置 不按照常规设置&#xff0c;点开下面的辅助功能->大号文本&#xff08;没有设置具体字号的选项&#xff0c;但是可以放大&#xff09; 效果图如下…

day-10 删除排序链表中的重复元素

思路 先统计每个值出现的次数&#xff0c;然后将出现次数为一的节点链接为一个链表即可 解题方法 while(t!null){ //统计每个值出现次数 arr[t.val100]1; tt.next; } while(t!null&&arr[t.val100]!1) tt.next;//确定返回的头结点 ttt; while(t!null&&t.next…

项目解决方案:多个分厂的视频监控汇聚到总厂

目 录 1、概述 2、建设目标及需求 2.1 建设目标 2.2 需求描述 2.3 需求分析 3. 设计依据与设计原则 3.1 设计依据 3.2设计原则 1、先进性与适用性 2、经济性与实用性 3、可靠性与安全性 4、开放性 5、可扩充性 6、追求最优化的系统设备配置…

Zynq7020 使用 Video Processing Subsystem 实现图像缩放

1、前言 没玩过图像缩放都不好意思说自己玩儿过FPGA&#xff0c;这是CSDN某大佬说过的一句话&#xff0c;鄙人深信不疑。。。 目前市面上主流的FPGA图像缩放方案如下&#xff1a;1&#xff1a;Xilinx的HLS方案&#xff0c;该方案简单&#xff0c;易于实现&#xff0c;但只能用…

java+vue基于Spring Boot的渔船出海及海货统计系统

该渔船出海及海货统计系统采用B/S架构、前后端分离进行设计&#xff0c;并采用java语言以及springboot框架进行开发。该系统主要设计并完成了管理过程中的用户注册登录、个人信息修改、用户信息、渔船信息、渔船航班、海货价格、渔船海货、非法举报、渔船黑名单等功能。该系统操…

Elasticsearch安装Windows版

目录 1.&#xff1a;下载安装包&#xff0c;选择指定的版本&#xff0c;这里选择了7.8.0&#xff0c;官网下载地址&#xff1a; ​编辑 2&#xff1a;下载好之后解压&#xff0c;解压之后是这样的&#xff1a; 3&#xff1a;配置环境变量&#xff0c;跟JDK一样&#xff0c;…

rime中州韵小狼毫 联想词组 滤镜

教程目录&#xff1a;rime中州韵小狼毫须鼠管安装配置教程 保姆级教程 100增强功能配置教程 在 rime中州韵小狼毫 自定义词典 一文中&#xff0c;我们分享了如何在rime中州韵小狼毫须鼠管输入法中定义用户自定义词典&#xff1b;通过自定义词典&#xff0c;我们可以很方便的在…

*(长期更新)软考网络工程师学习笔记——Section 22 无线局域网

目录 一、IEEE 802.11的定义二、IEEE 802.11系列标准三、IEEE 802.11的两种工作模式四、CDMA/CA协议&#xff08;一&#xff09;CDMA/CA协议的定义&#xff08;二&#xff09;CDMA/CA协议的过程 五、AC与AP&#xff08;一&#xff09;接入控制器AC&#xff08;二&#xff09;无…

MySQL解决海量数据和并发性的方案——分库分表

分库分表其实是两个事情&#xff0c;为了解决的东西实际上也是两个&#xff0c;但是一定要注意&#xff0c;不到最后万不得已&#xff0c;不要用分库分表&#xff0c;因为这会对数据查询有极大限制。 数据量太大查询慢的问题。 这里面我们讲的「查询」其实 主要是事务中的查询…

如何实现图片压缩

文章目录 1、canvas实现图片压缩2、其他 1、canvas实现图片压缩 canvas 实现图片压缩&#xff0c;主要是使用 canvas 的drawImage 方法 具体思路 拿到用户上传的文件转成base64创建一个 Image&#xff0c;主要是获取到这个图片的宽度和高度创建一个 2D 的画布&#xff0c;画布…

一文搞懂系列——Linux C线程池技术

背景 最近在走读诊断项目代码时&#xff0c;发现其用到了线程池技术&#xff0c;感觉耳目一新。以前基本只是听过线程池&#xff0c;但是并没有实际应用。对它有一丝的好奇&#xff0c;于是趁这个机会深入了解一下线程池的实现原理。 线程池的优点 线程池出现的背景&#xf…

RocketMQ源码阅读-Message拉取与消费-Broker篇

RocketMQ源码阅读-Message拉取与消费-Broker篇 1. ConsumeQueue是什么2. Message重放2.1 从MappedFile文件读取Message到ConsumeQueue2.2 ConsumeQueue持久化 3. Broker提供的拉取接口3.1 请求Header3.2 拉取消息接口3.3 拉取失败处理 4. Broker提供的更新消费进度接口5. Broke…

短视频IP运营流程架构SOP模板PPT

【干货资料持续更新&#xff0c;以防走丢】 短视频IP运营流程架构SOP模板PPT 部分资料预览 资料部分是网络整理&#xff0c;仅供学习参考。 抖音运营资料合集&#xff08;完整资料包含以下内容&#xff09; 目录 抖音15秒短视频剧本创作公式 在抖音这个短视频平台上&#…

SpringBoot集成RabbitMq,RabbitMq消费与生产,消费失败重发机制,发送签收确认机制

RabbitMq消费与生产&#xff0c;消费失败重发机制&#xff0c;发送确认机制&#xff0c;消息发送结果回执 1. RabbitMq集成spring bootRabbitMq集成依赖RabbitMq配置RabbitMq生产者&#xff0c;队列&#xff0c;交换通道配置&#xff0c;消费者示例 2. RabbitMq消息确认机制消息…

【例7.5】 取余运算(mod) 快速幂

1326&#xff1a;【例7.5】 取余运算&#xff08;mod&#xff09; 时间限制: 1000 ms 内存限制: 65536 KB 【题目描述】 输入b&#xff0c;p&#xff0c;k的值&#xff0c;求bpmodk 的值。其中b&#xff0c;p&#xff0c;kk为长整型数。 【输入】 输入b&#xff0c;p&#xf…

Scott用户数据表的分析

Oracle从入门到总裁:https://blog.csdn.net/weixin_67859959/article/details/135209645 如果想要知道某个用户所有的数据表: select * from tab; 此时结果中一共返回了四张数据表&#xff0c;分别为部门表&#xff08;dept&#xff09; &#xff0c;员工表&#xff08;emp&a…

【LV12 DAY20 RTC实验】

编程实现通过LED状态显示当前电压范围&#xff0c;并打印产生低压警报时的时间 注&#xff1a; 电压在1501mv~1800mv时&#xff0c;LED2、LED3、LED4、LED5点亮 电压在1001mv~1500mv时&#xff0c;LED2、LED3、LED4点亮 电压在501mv~1000mv时&#xff0c;LED2、LED3点亮 电压在…

HTML--CSS--浮动布局及定位布局

正常文档布局 块元素独占一行 行内元素在有多个的时候&#xff0c;就是从左到右排在一行 块元素包括&#xff1a;div,p,hr 行内元素&#xff1a;span,i,img 浮动布局 float 属性&#xff1a; left 向左 right 向右 作用我目前看起来就是浮动元素的宽度是由内容决定的&#x…

HDFS和MapReduce综合实训

文章目录 第1关&#xff1a;WordCount词频统计第2关&#xff1a;HDFS文件读写第3关&#xff1a;倒排索引第4关&#xff1a; 网页排序——PageRank算法 第1关&#xff1a;WordCount词频统计 测试说明 以下是测试样例&#xff1a; 测试输入样例数据集&#xff1a;文本文档test1…