MySQL多表连接查询3
目录
表结构
创建表
表数据
查询需求:
1.查询student表的所有记录
2.查询student表的第2条到4条记录
3.从student表查询所有学生的学号(id)、姓名(name)和院系(department)的信息
4.从student表中查询计算机系和英语系的学生的信息
5.从student表中查询年龄18~22岁的学生信息
6.从student表中查询每个院系有多少人
7.从score表中查询每个科目的最高分
8.查询李四的考试科目(c_name)和考试成绩(grade)
9.用连接的方式查询所有学生的信息和考试信息
10.计算每个学生的总成绩
11.计算每个考试科目的平均成绩
12.查询计算机成绩低于95的学生信息
13.查询同时参加计算机和英语考试的学生的信息
14.将计算机考试成绩按从高到低进行排序
15.从student表和score表中查询出学生的学号,然后合并查询结果
16.查询姓张或者姓王的同学的姓名、院系和考试科目及成绩
17.查询都是湖南的学生的姓名、年龄、院系和考试科目及成绩
表结构
student
score
创建表
插入语句:
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)
-> );
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)
-> );
表数据
插入语句:
向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);
查询需求:
1.查询student表的所有记录
select *from student;

2.查询student表的第2条到4条记录
select *from student limit 1,3;

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

4.从student表中查询计算机系和英语系的学生的信息
select *from student where department in ('中文系','计算机系');

5.从student表中查询年龄18~22岁的学生信息
假定当时记录时的年份为2010年
select *,(2010-student.birth) as age from student inner join score on score.stu_id=student.id where (2010-student.birth) between 18 and 22;

6.从student表中查询每个院系有多少人
select department,count(*) from student group by department;

7.从score表中查询每个科目的最高分
select c_name,max(grade) from score group by c_name;

8.查询李四的考试科目(c_name)和考试成绩(grade)
select c_name,grade from score inner join student on score.stu_id=student.id where student.name='李四';

9.用连接的方式查询所有学生的信息和考试信息
select *from score inner join student on score.stu_id=student.id;

10.计算每个学生的总成绩
select name,sum(grade) from student inner join score on score.stu_id=student.id group by score.stu_id;

11.计算每个考试科目的平均成绩
select c_name,avg(grade) from student inner join score on score.stu_id=student.id group by score.c_name;

12.查询计算机成绩低于95的学生信息
select *from student inner join score on score.stu_id=student.id where score.c_name='计算机' and score.grade<95;

13.查询同时参加计算机和英语考试的学生的信息
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='计算机'));

14.将计算机考试成绩按从高到低进行排序
select *from student inner join score on student.id=score.stu_id where score.c_name='计算机' order by score.grade desc;

15.从student表和score表中查询出学生的学号,然后合并查询结果
select distinct student.id,student.name from student inner join score on student.id=score.stu_id;

16.查询姓张或者姓王的同学的姓名、院系和考试科目及成绩
select name,department,c_name,grade from student inner join score on student.id=score.stu_id where student.name regexp '^[张|王]';

17.查询都是湖南的学生的姓名、年龄、院系和考试科目及成绩
假定当时记录时的年份为2010年
select name,(2010-birth) as age, department,c_name,grade from student inner join score on student.id=score.stu_id where left(student.address,2)='湖南';

相关文章:
MySQL多表连接查询3
目录 表结构 创建表 表数据 查询需求: 1.查询student表的所有记录 2.查询student表的第2条到4条记录 3.从student表查询所有学生的学号(id)、姓名(name)和院系(department)的信息 4.从s…...
【从零开始学习JAVA | 第四十五篇】反射
目录 前言: 反射: 使用反射的步骤: 1.获取阶段: 2.使用阶段: 反射的应用场景: 使用反射的优缺点: 总结: 前言: Java中的反射是一项强大而灵活的功能࿰…...
顺丰科技数据治理实践
01 顺丰数据治理体系演进路线 顺丰做数据治理十多年,数据治理体系的模块是逐步来建设的。十年前,我们就已经建了数仓,同步做了元数据管理,数据质量管理,以及数据安全的管理。顺丰数据治理的演进路线分 3 个阶段。 第…...
Nginx+Tomcat负载均衡、动静分离实例详细部署
一、反向代理两种模式 四层反向代理 基于四层的iptcp/upd端口的代理 他是http块同一级,一般配置在http块上面。 他是需要用到stream模块的,一般四层里面没有自带,需要编译安装一下。并在stream模块里面添加upstream 服务器名称,…...
Java多线程(3)---锁策略、CAS和JUC
目录 前言 一.锁策略 1.1乐观锁和悲观锁 ⭐ 两者的概念 ⭐实现方法 1.2读写锁 ⭐概念 ⭐实现方法 1.3重量级锁和轻量级锁 1.4自旋锁和挂起等待锁 ⭐概念 ⭐代码实现 1.5公平锁和非公平锁 1.6可重入锁和不可重入锁 二.CAS 2.1为什么需要CAS 2.2CAS是什么 ⭐CAS…...
Linux:Shell编辑之文本处理器(awk)
目录 绪论 1、用法 1.1 格式选项 1.2 awk 常用内置变量 1.3 awk的打印功能 1.4 奇偶打印 1.5 awk运算 1.6 awk的内置函数:getline 1.7 文本过滤打印 1.8 awk条件判断打印 1.9 三元表达式,类似于java 1.10 awk的精确筛选 1.11 awk和tr比较改变…...
探索FSM (有限状态机)应用
有限状态机(FSM) 是计算机科学中的一种数学模型,可用于表示和控制系统的行为。它由一组状态以及定义在这些状态上的转换函数组成。FSM 被广泛用于计算机程序中的状态机制。 有限状态机(FSM)应用场景 在各种自动化系统…...
6.continue break
6.1continue 关键字 continue 关键字用于立即跳出本次循环,继续下一次循环(本次循环体continue之后的代码会少执行一次)。 例如:吃5个包子,第3个有虫子,就扔掉第3个包子,继续吃第4个第5个包子…...
如何在Linux中强制关闭卡住的PyCharm
在使用PyCharm进行Python开发时,有时可能会遇到卡顿或无响应的情况。当PyCharm卡住时,我们需要强制关闭它以恢复正常操作。今天,我们将介绍在Linux系统中如何强制关闭PyCharm的几种方法。 1. 使用键盘快捷键 在PyCharm所在的窗口中…...
c# Excel数据的导出与导入
搬运:Datagrideview 数据导出Excel , Exel数据导入 //------------------------------------------------------------------------------------- // All Rights Reserved , Copyright (C) 2013 , DZD , Ltd . //----------------------------------------------------------…...
Kotlin~Mediator中介者模式
概念 创建一个中介来降低对象之间的耦合度,关系”多对多“变为“一对多”。 角色介绍 Mediator:抽象中介者,接口或者抽象类。ConcreteMediator:中介者具体实现,实现中介者接口,定义一个List管理Colleagu…...
石子合并问题
一.试题 在一个园形操场的四周摆放N堆石子(N≤100),现要将石子有次序地合并成一堆。规定 每次只能选相邻的两堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分。 编一程序,由文件读入…...
剑指Offer-搜索与回溯算法
文章目录 剑指 Offer 32 - I. 从上到下打印二叉树题意:解:代码: 剑指 Offer 32 - II. 从上到下打印二叉树 II题意:解:代码: 剑指 Offer 32 - III. 从上到下打印二叉树 III题意:解:代…...
【云原生】Docker 详解(三):Docker 镜像管理基础
Docker 详解(三):Docker 镜像管理基础 1.镜像的概念 镜像可以理解为应用程序的集装箱,而 Docker 用来装卸集装箱。 Docker 镜像含有启动容器所需要的文件系统及其内容,因此,其用于创建并启动容器。 Dock…...
SD-MTSP:蜘蛛蜂优化算法SWO求解单仓库多旅行商问题MATLAB(可更改数据集,旅行商的数量和起点)
一、蜘蛛蜂优化算法SWO 蜘蛛蜂优化算法(Spider wasp optimizer,SWO)由Mohamed Abdel-Basset等人于2023年提出,该算法模型雌性蜘蛛蜂的狩猎、筑巢和交配行为,具有搜索速度快,求解精度高的优势。蜘蛛蜂优化算…...
【ARM 嵌入式 编译系列 3.1 -- GCC __attribute__((used)) 使用】
文章目录 __attribute__((used)) 属性介绍代码演示编译与输出GCC 编译选项 上篇文章:ARM 嵌入式 编译系列 3 – GCC attribute((weak)) 弱符号使用 下篇文章:ARM 嵌入式 编译系列 3.2 – glibc 学习 __attribute__((used)) 属性介绍 在普通的 C/C 程序中…...
C++ ModBUS TCP客户端工具 qModMaster 介绍及使用
qModMaster工具介绍 QModMaster是一个基于Qt的Modbus主站(Master)模拟器,用于模拟和测试Modbus TCP和RTU通信。它提供了一个直观的图形界面,使用户能够轻松设置和发送Modbus请求,并查看和分析响应数据。 以下是QModM…...
笔记本电脑如何把sd卡数据恢复
在使用笔记本电脑过程中,如果不小心将SD卡里面的重要数据弄丢怎么办呢?别着急,本文将向您介绍SD卡数据丢失常见原因和恢复方法。 ▌一、SD卡数据丢失常见原因 - 意外删除:误操作或不小心将文件或文件夹删除。 - 误格式化&#…...
【2023 华数杯全国大学生数学建模竞赛】 B题 不透明制品最优配色方案设计 39页论文及python代码
【2023 华数杯全国大学生数学建模竞赛】 B题 不透明制品最优配色方案设计 39页论文及python代码 1 题目 B 题 不透明制品最优配色方案设计 日常生活中五彩缤纷的不透明有色制品是由着色剂染色而成。因此,不透明制品的配色对其外观美观度和市场竞争力起着重要作用。…...
Exams/ece241 2013 q4
蓄水池问题 S3 S2 S1 例如:000 代表 无水 ,需要使FR3, FR2, FR1 都打开(111) S3 S2 S1 FR3 FR2 FR1 000 111 001 011 011 001 111 000 fr代表水变深为…...
用Unity 2D复刻经典:如何为你的“Ruby‘s Adventure”添加完整的任务系统与NPC对话(含C#脚本详解)
用Unity 2D构建可扩展任务系统:从Rubys Adventure到RPG游戏开发实战 在独立游戏开发领域,叙事与玩法机制的融合一直是提升玩家沉浸感的关键。Unity官方教程项目Rubys Adventure作为2D游戏开发的经典入门案例,虽然展示了基础交互的实现&#x…...
闲鱼自动化采集系统实战指南:智能监控与精准推送解决方案
闲鱼自动化采集系统实战指南:智能监控与精准推送解决方案 【免费下载链接】idlefish_xianyu_spider-crawler-sender 闲鱼自动抓取/筛选/发送系统,xianyu spider crawler blablabla 项目地址: https://gitcode.com/gh_mirrors/id/idlefish_xianyu_spide…...
别再死记公式了!用PyTorch手把手实现多头自注意力,从矩阵变换到完整分类器
从零实现多头自注意力:用PyTorch拆解Transformer核心模块 当第一次看到Transformer架构中的多头自注意力(Multi-head Self-Attention)时,那些复杂的矩阵运算和维度变换是否让你望而生畏?本文将通过代码实操带你穿透数学…...
Android-Clean-Boilerplate与RxJava对比:为什么选择普通Java实现
Android-Clean-Boilerplate与RxJava对比:为什么选择普通Java实现 【免费下载链接】Android-Clean-Boilerplate This is starter template for writing Android apps using Clean architecture 项目地址: https://gitcode.com/gh_mirrors/an/Android-Clean-Boilerp…...
Qwen3.5-4B-AWQ保姆级教程:WebUI界面Prompt工程最佳实践
Qwen3.5-4B-AWQ保姆级教程:WebUI界面Prompt工程最佳实践 1. 模型介绍与环境准备 Qwen3.5-4B-AWQ-4bit是阿里云通义千问团队推出的轻量级大语言模型,经过4bit AWQ量化后显存占用仅约3GB,可在RTX 3060/4060等消费级显卡上流畅运行。该模型在保…...
深度学习图像描述数据集构建全流程解析
1. 项目概述:构建深度学习图像描述数据集的核心逻辑在计算机视觉与自然语言处理的交叉领域,图像描述生成(Image Captioning)一直是极具挑战性的任务。这个项目的本质,是通过系统化的数据工程方法,将原始图像…...
高速背板设计中的信号完整性挑战与解决方案
1. 高速背板设计中的信号完整性挑战在当今5G通信、AI计算和高速网络设备中,背板作为连接多个功能模块的核心枢纽,其信号完整性直接决定了整个系统的性能和可靠性。我曾参与过一个400G光模块背板项目,当频率提升到28GHz时,原本在低…...
KV缓存安全风险与多租户环境防护实践
1. KV缓存安全风险与多租户环境下的挑战在构建基于Transformer架构的大语言模型(LLM)和视觉语言模型(VLM)应用时,我们通常会采用KV(Key-Value)缓存机制来提升推理性能。这种优化技术通过缓存模型处理过的token中间状态,使得相同前缀的后续请求可以跳过重…...
终极Tiled插件开发指南:30分钟打造专属游戏地图导出器
终极Tiled插件开发指南:30分钟打造专属游戏地图导出器 【免费下载链接】tiled Flexible level editor 项目地址: https://gitcode.com/gh_mirrors/ti/tiled 还在为游戏引擎不兼容Tiled地图格式而烦恼吗?还在手动转换地图数据浪费宝贵开发时间吗&a…...
告别数据抖动!手把手教你配置SGM58200 ADC的50/60Hz工频抗干扰采样(附STM32 I2C代码)
工业级ADC抗干扰实战:SGM58200精准抑制50/60Hz工频噪声的配置指南 在工业测量和传感器信号采集中,工频干扰就像一位不请自来的"噪音制造者"。当你的精密仪器读数出现周期性波动,或是数据采集结果出现难以解释的抖动时,很…...
