MySQL单表查询与多表查询

目录

一、单表查询

​编辑

1、显示所有职工的基本信息。  

​编辑2、查询所有职工所属部门的部门号,不显示重复的部门号。

 ​编辑3、求出所有职工的人数。  

4、列出最高工和最低工资。   

​编辑5、列出职工的平均工资和总工资。   

​编辑6、创建一个只有职工号、姓名和参加工作的新表,名为工作日期表。 

​编辑

​编辑 7、列出1960年以前出生的职工的姓名、参加工作日期。

​编辑

8、列出工资在1000-2000之间的所有职工姓名。 

9、列出所有陈姓和李姓的职工姓名。

10、列出所有部门号为2和3的职工号、姓名、是否是党员。  

​编辑11、将职工表worker中的职工按出生的先后顺序排序。

12、显示工资最高的前3名职工的职工号和姓名。

 ​编辑13、求出各部门党员的人数。 

​编辑14、统计各部门的工资和平均工资

​编辑15、列出总人数大于4的部门号和总人数

二、多表查询

1.创建student和score表

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

3.查询student表的所有记录

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

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

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

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

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

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

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

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

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

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

​编辑14.查询计算机成绩低于95的学生信息​编辑15.查询同时参加计算机和英语考试的学生的信息

​编辑

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

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

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

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


一、单表查询


素材: 表名:worker-- 表中字段均为中文,比如 部门号 工资 职工号 参加工作 等

CREATE TABLE `worker` (`部门号` int(11) NOT NULL,`职工号` int(11) NOT NULL,`工作时间` date NOT NULL,`工资` float(8,2) NOT NULL,`政治面貌` varchar(10) NOT NULL DEFAULT '群众',`姓名` varchar(20) NOT NULL,`出生日期` date NOT NULL,PRIMARY KEY (`职工号`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;

INSERT INTO `worker` (`部门号`, `职工号`, `工作时间`, `工资`, `政治面貌`, `姓名`, `出生
日期`) VALUES (101, 1001, '2015-5-4', 3500.00, '群众', '张三', '1990-7-1');
INSERT INTO `worker` (`部门号`, `职工号`, `工作时间`, `工资`, `政治面貌`, `姓名`, `出生
日期`) VALUES (101, 1002, '2017-2-6', 3200.00, '团员', '李四', '1997-2-8');
INSERT INTO `worker` (`部门号`, `职工号`, `工作时间`, `工资`, `政治面貌`, `姓名`, `出生
日期`) VALUES (102, 1003, '2011-1-4', 8500.00, '党员', '王亮', '1983-6-8');
INSERT INTO `worker` (`部门号`, `职工号`, `工作时间`, `工资`, `政治面貌`, `姓名`, `出生
日期`) VALUES (102, 1004, '2016-10-10', 5500.00, '群众', '赵六', '1994-9-5');
INSERT INTO `worker` (`部门号`, `职工号`, `工作时间`, `工资`, `政治面貌`, `姓名`, `出生
日期`) VALUES (102, 1005, '2014-4-1', 4800.00, '党员', '钱七', '1992-12-30');
INSERT INTO `worker` (`部门号`, `职工号`, `工作时间`, `工资`, `政治面貌`, `姓名`, `出生
日期`) VALUES (102, 1006, '2017-5-5', 4500.00, '党员', '孙八', '1996-9-2');

1、显示所有职工的基本信息。  


2、查询所有职工所属部门的部门号,不显示重复的部门号。

使用DISTINCT关键字可从查询结果中清除重复行

 
3、求出所有职工的人数。  

4、列出最高工和最低工资。   


5、列出职工的平均工资和总工资。   


6、创建一个只有职工号、姓名和参加工作的新表,名为工作日期表。 

 
7、列出1960年以前出生的职工的姓名、参加工作日期。

如图,并没有1960年前出生的职工。

插入一条后再去查询

8、列出工资在1000-2000之间的所有职工姓名。 

两种查询方法

 

9、列出所有陈姓和李姓的职工姓名。

正则表达式方法: 

10、列出所有部门号为2和3的职工号、姓名、是否是党员。  


11、将职工表worker中的职工按出生的先后顺序排序。

默认为升序即asc,而降序为desc

12、显示工资最高的前3名职工的职工号和姓名。

 13、求出各部门党员的人数。 


14、统计各部门的工资和平均工资


15、列出总人数大于4的部门号和总人数

二、多表查询

1.创建student和score表

CREATE  TABLE student1 (
id  INT(10)  NOT NULL  UNIQUE  PRIMARY KEY ,
name  VARCHAR(20)  NOT NULL ,
sex  VARCHAR(4) ,
birth  YEAR,
department  VARCHAR(20) ,
address  VARCHAR(50)
);
创建score表。SQL代码如下:
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表增加记录

向student1表插入记录的INSERT语句如下:
INSERT INTO student1 VALUES( 901,'张老大', '男',1985,'计算机系', '北京市海淀区');
INSERT INTO student1 VALUES( 902,'张老二', '男',1986,'中文系', '北京市昌平区');
INSERT INTO student1 VALUES( 903,'张三', '女',1990,'中文系', '湖南省永州市');
INSERT INTO student1 VALUES( 904,'李四', '男',1990,'英语系', '辽宁省阜新市');
INSERT INTO student1 VALUES( 905,'王五', '女',1991,'英语系', '福建省厦门市');
INSERT INTO student1 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表的所有记录


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


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


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


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


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


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


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

inner join:代表选择的是两个表的交差部分

SELECT 列名1,列名2... FROM 表1 INNER JOIN 表2 ON 表1.外键=表2.主键 WhERE 条件语句;

(这里还用到了子查询)


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

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

使用11题的表进行子查询有两个‘id’导致报错

简化子查询即可


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


14.查询计算机成绩低于95的学生信息
15.查询同时参加计算机和英语考试的学生的信息

由于mysql是一行一行查询的所以使用以下语句并不能查询到

思路:先将学计算机和学英语的分别列出 ,

 然后将两表关联查询的结果作为子查询即可

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


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


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


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

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

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

相关文章

【数据结构】队列实现+层序遍历详解+一些练题

欢迎来到我的:世界 希望作者的文章对你有所帮助,有不足的地方还请指正,大家一起学习交流 ! 目录 前言队列的实现层序遍历详解强化练习1.判断是不是完全二叉树求二叉树的最大深度 总结 前言 国庆到了,也要内卷一下,感…

ElasticSearch 同步数据变少了

一、前言 这几天对接ES遇到几个坑,我们将一张库存表同步到ES发现Docs Count和我们表中的数据对不上,需要加上Docs deleted才对得上,也不知道批量写入数据为什么有些数据就会成 Docs deleted。 二、ID和版本号 ES中每一个Document都有一个_…

c#中的接口

使用IEnumerable统一迭代变量类型 class Program {static void Main(string[] args){int[] nums1 new int[] { 1, 2, 3, 4, 5 };ArrayList nums2 new ArrayList { 1, 2, 3, 4, 5 };Console.WriteLine(Sum(nums1));Console.WriteLine(Sum(nums2));Console.WriteLine(Avg(nums…

oracle-使用PLSQL工具自行修改用户密码

1、使用PLSQL工具,输入用户名和原密码登录,如下图 2、登录后,在会话下拉菜单中找到”Change password..” 3、在跳出的窗口中配置新密码,修改完成后单击”确认”,后退出PLSQL 4、重新打开PLSQL,使用新密码登…

【Spring Cloud】深入理解 Eureka 注册中心的原理、服务的注册与发现

文章目录 前言一、微服务调用出现的问题1.1 服务消费者如何获取服务提供者的地址信息?1.2 如果有多个服务提供者,消费者该如何选择?1.3 消费者如何得知服务提供者的健康状态? 二、什么是 Eureka2.1 Eureka 的核心概念2.2 Eureka 的…

C语言数据结构之排序整合与比较(冒泡,选择,插入,希尔,堆排序,快排及改良,归并排序,计数排序)

前言:排序作为数据结构中的一个重要模块,重要性不言而寓,我们的讲法为下理论掌握大致的算法结构,再上代码及代码讲解,助你一臂之力。 一,冒泡 冒泡排序应该是大家学习以来第一个认识的排序方法&#xff0…

buuctf-[WUSTCTF2020]CV Maker

打开环境 随便登录注册一下 进入到了profile.php 其他没有什么页面&#xff0c;只能更换头像上传文件&#xff0c;所以猜测是文件上传漏洞 上传一句话木马看看 <?php eval($_POST[a]);?>回显 搜索一下 添加文件头GIF89a。上传php文件 查看页面源代码&#xff0c;看…

Leetcode---364场周赛

题目列表 2864. 最大二进制奇数 2865. 美丽塔 I 2866. 美丽塔 II 2867. 统计树中的合法路径数目 一、最大二进制奇数 这题只要你对二进制有了解(学编程的不会不了解二进制吧)&#xff0c;应该问题不大&#xff0c;这题要求最大奇数&#xff0c;1.奇数&#xff1a;只要保证…

谷歌扩展下载

Chrome 扩展下载安装网站推荐 # 1. 极简插件优质crx应用 ●地址&#xff1a;https://chrome.zzzmh.cn ●推荐&#xff1a;★★★★★ 一个非常良心 & 干净 & 简洁的 Chrome 扩展下载网站&#xff0c;体验非常不错&#xff01; 侧边栏可以通过类型对扩展进行筛选和排序&…

Android LiveData 介绍

Android LiveData 介绍 系列文章目录前言一、LiveData是什么&#xff1f;二、简单使用依赖测试数据准备1.创建可观察的livedata2.观察它3.更新它 总结 系列文章目录 Android LiveData 介绍&#xff08;本文&#xff09; 前言 本系列根据官网介绍Jetpack中的数据通信组件&…

大数据Doris(三):Doris编译部署篇

文章目录 Doris编译部署篇 一、Doris编译

侯捷 C++ STL标准库和泛型编程 —— 4 分配器 + 5 迭代器

4 分配器 4.1 测试 分配器都是与容器共同使用的&#xff0c;一般分配器参数用默认值即可 list<string, allocator<string>> c1;不建议直接用分配器分配空间&#xff0c;因为其需要在释放内存时也要指明大小 int* p; p allocator<int>().allocate(512,…

图像处理: 马赛克艺术

马赛克 第一章 马赛克的历史渊源 1.1 马赛克 艺术中的一种表面装饰&#xff0c;由紧密排列的、通常颜色各异的小块材料&#xff08;如石头、矿物、玻璃、瓷砖或贝壳&#xff09;组成。与镶嵌不同的是&#xff0c;镶嵌是将要应用的部件放置在已挖空以容纳设计的表面中&#xff0…

babel.config.js配置文件详解

文章目录 一、前言三、babel 详解四、拓展阅读 一、前言 项目开发阶段&#xff0c;使用可选链操作符 ?. 出现以下编译报错问题&#xff1a; 分析&#xff1a;由于可选链操作符 ?. 是ES2020&#xff08;即ES11&#xff09;中推出的新语法&#xff0c;允许我们不需要校验当前属…

imgui开发笔记<1>、ubuntu环境下快速应用

去这个链接下载imgui源码&#xff08;在此之前需要安装opengl glfw3等等&#xff09;&#xff1a; sudo apt-get install libglfw3-dev https://github.com/ocornut/imgui 我这里源码下载到/home/temp/imgui目录下&#xff0c;咱们不需要编译源码成库&#xff0c;而是直接将下…

网页采集工具-免费的网页采集工具

在当今数字化时代&#xff0c;网页采集已经成为了众多领域的必备工具。无论是市场研究、竞争情报、学术研究还是内容创作&#xff0c;网页采集工具都扮演着不可或缺的角色。对于许多用户来说&#xff0c;寻找一个高效、免费且易于使用的网页采集工具太不容易了。 147SEO工具的强…

使用prometheus监控java服务

在prometheus官方下载页面没有看到jvm_exproter的下载地址但是官方页面是有推荐下载地址的 访问 Prometheus - Monitoring system & time series database prometheus官方网址 官方推荐地址下载是在github网络访问不方便的可以用下面的网址 wget https://repo1.maven…

SpringCloud Gateway--Predicate/断言(详细介绍)中

&#x1f600;前言 本篇博文是关于SpringCloud Gateway–Predicate/断言&#xff08;详细介绍&#xff09;中&#xff0c;希望你能够喜欢 &#x1f3e0;个人主页&#xff1a;晨犀主页 &#x1f9d1;个人简介&#xff1a;大家好&#xff0c;我是晨犀&#xff0c;希望我的文章可以…

51单片机数字电压表仿真设计_LCD显示(仿真+程序+原理图+PCB+设计报告+讲解)

51单片机数字电压表仿真设计_LCD显示&#xff08;仿真程序原理图PCB设计报告讲解&#xff09; 原理图&#xff1a;Altium Designer 仿真版本&#xff1a;proteus 7.8 程序编译器&#xff1a;keil 4/keil 5 编程语言&#xff1a;C语言 设计编号&#xff1a;S0006 51单片机数…

【新版】系统架构设计师 - 未来信息综合技术

个人总结&#xff0c;仅供参考&#xff0c;欢迎加好友一起讨论 文章目录 架构 - 未来信息综合技术考点摘要信息物理系统CPS的体系架构CPS 的技术体系CPS应用场景 人工智能分类关键技术机器学习 机器人发展分类机器人4.0 边缘计算概念与特点边云协同安全应用场景 数字孪生关键技…