Mysql数据库 9.SQL语言 查询语句 连接查询、子查询

连接查询

通过查询多张表,用连接查询进行多表联合查询

关键字:inner join 内连接

               left join 左连接

               right join 右连接 

数据准备

创建新的数据库:create database 数据库名;

create database db_test2;

使用数据库:use 数据库名;

use db_test2;

创建班级信息表:

create table 表名(字段名1,字段名2,......);

代码实现
create table classes(
	class_id int primary key auto_increment,#主键自增
	class_name varchar(40) not null unique,
	class_remark varchar(200)
);

创建学生表:

create table 表名(字段名1,字段名2,......);

代码实现
create table students(
	stu_num char(8) primary key ,
	stu_name varchar(20) not null,
	stu_gender char(2) not null,
	stu_age int not null,
	cid int,
	constraint FK_STUDENTS_CLASSES foreign key(cid) 
	references classes(class_id)
	on update cascade ON DELETE CASCADE
);

添加班级信息

insert into 表名 (字段名)values(添加的数据);

代码实现
insert into classes (class_name,class_remark)values('Java2204','......');

insert into classes (class_name,class_remark)values('Java2205','......');

insert into classes (class_name,class_remark)values('Java2206','......');

insert into classes (class_name,class_remark)values('Python','......');
运行结果

添加学生信息

以下三个信息,属于class_id=1 的班级 (Java2204)

代码实现
insert into students (stu_num,stu_name,stu_gender,stu_age,cid)
values('20220101','张三','男',20,1);

insert into students (stu_num,stu_name,stu_gender,stu_age,cid)
values('20220102','李四','女',20,1);

insert into students (stu_num,stu_name,stu_gender,stu_age,cid)
values('20220103','王五','男',20,1);

以下两个学生信息,属于class_id=2 的班级 (Java2205)

代码实现
insert into students (stu_num,stu_name,stu_gender,stu_age,cid)
values('20220104','赵婷','女',20,1);

insert into students (stu_num,stu_name,stu_gender,stu_age,cid)
values('20220105','孙七','男',20,2);

小红和小明没有设置班级信息

代码实现
insert into students (stu_num,stu_name,stu_gender,stu_age)
values('20220106','小红','女',20);

insert into students (stu_num,stu_name,stu_gender,stu_age)
values('20220107','小明','男',20);
运行结果

select * from 表名;查询表

代码实现
select * from students s ;
select * from classes c ;
运行结果

内连接

语法

select ...... from 表名1 inner join 表名2 on 匹配条件 [where 条件];

经过内连接(表连接)之后,将两张表的数据以笛卡尔积的效果进行连接

代码实现

select * from 表名1 inner join 表名2;

select * from students inner join classes;

 运行结果

产生笛卡尔积,效果如下,将表1中的每个数据与第二个表中的每个数据都进行匹配

7 * 3 = 28,共有28个数据

消除笛卡尔积,在前缀后加上 on 匹配条件 [where 条件];

select ...... from 表名1 inner join 表名2 on 匹配条件 [where 条件]; 

内连接条件

两张表使用inner join连接查询之后生产的笛卡尔积数据中很多数据都是无意义的,我们如何消除无意义的数据呢?——添加两张进行连接查询时的匹配条件

使用 on 设置两张表连接查询时的匹配条件

两张表连接查询+条件

代码实现

使用where进行两个表之间的连接

select * from students inner join classes where students.cid=classes.class_id ;
运行结果
代码实现

使用on进行两个表之间的连接

select * from students inner join classes on students.cid=classes.class_id ;
运行结果

on连接查询和where连接查询的区别

where筛选:先生成笛卡尔积后进行判断连接条件是否成立

on筛选:先进行判断连接条件是否成立,如果成立后,再会进行组合,就不会有笛卡尔积的结果

左连接 LEFT JOIN

左连接定义

左连接显示左表中的所有数据,如果在右表中存在与左表记录满足匹配条件的数据,则进行匹配,如果右表中不存在匹配数据,则显示为NULL;

语法

select * from 左表名 left join 右表名 on 匹配条件 [where 条件];

作用

左连接:显示左表中的所有记录

需求

请查询出所有学生信息,如果有学生有对应的班级信息,则将对应的班级信息也查询出来

代码实现
select * from students left join classes on students.cid=classes.class_id ;

运行结果

右连接 RIGHT JOIN

右连接定义

右连接显示右表中的所有数据,如果在左表中存在与右表记录满足匹配条件的数据,则进行匹配,如果左表中不存在匹配数据,则显示为NULL;

语法

select * from 表名1 RIGHT JOIN 表名2 ON 表名1与表名2的关联字符;

作用

右连接:显示右表中的所有记录

需求

将右表中的所有数据显示出来

代码实现
select * from students right join classes on students.cid=classes.class_id ;

运行结果

左连接、右连接与内连接的区别

内连接:只会显示出两表中有关联的数据

左连接:显示出左表中的所有数据,右表中只写有关联的数据

右连接:显示出右表中的所有数据,左表中只写有关联的数据

数据表别名

语法

alter table 表名 rename column 列名 to 新列名;

案例

代码实现

修改列名

alter table students rename column stu_name to name;
alter table classes rename column class_name to name;

运行结果

当两个表的字段名称相同时,如何进行查询字段

代码实现
select students.name,classes.name from students inner join classes on students.cid = classes.class_id ;

运行结果

使用别名查询字段

代码实现
select s.name,c.name from students s inner join classes c on s.cid=c.class_id ;

运行结果 

子查询/嵌套查询 

定义

子查询——先进行一次查询,第一次查询的结果作为第二次查询的源/条件(第二次查询是基于第一次的查询结果来进行的)

子查询返回单个值——单行单列

案例 

查询班级表中字段名为Java2204的数据, 查询所有Java2204班级中选课副码为1的学生信息

代码实现

查询班级表中字段名为Java2204的数据

select class_id from classes c where name ='Java2204';

 查询所有Java2204班级中选课副码为1的学生信息

select * from students s where cid=1;

运行结果

查询所有Java班级中的学生信息 单列多行查询

代码实现
select class_id from classes c where name like 'Java%' ;

运行结果

显示三条查询语句 union连接关键字

代码实现
#显示三条查询语句 union连接关键字
select * from students s where cid=1
union
select * from students s where cid=2
union
select * from students s where cid=3;

运行结果

子查询,in关键字 单列多行查询

如果查询结果是单列多行,要有关键字in

in代表的是包含,not in代表不包含

代码实现
select * from students s where cid in(select class_id from classes c where name like 'Java%');

运行结果

 查询cid=1的班级中性别为男的学生信息

语法

select * from (select * from 表名 where 限制) 别名 where 别名.列名 = 限制;

将第一步查询语句当作一个虚拟表(限制信息)查询第二个表

代码实现
select * from (select * from students where cid = 1) t where t.stu_gender='男';

运行结果

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Day1 ARM基础

【ARM课程认知】 1.ARM课程的作用 承上启下 基础授课阶段:c语言、数据结构、linux嵌入式应用层课程:IO、进程线程、网络编程嵌入式底层课程:ARM体系结构、系统移植、linux设备驱动c/QT 2.ARM课程需要掌握的内容 自己能够实现简单的汇编编…

AI 绘画 | Stable Diffusion 图生图

图生图简介 Stable Diffusion 不仅可以文生图,还可以图生图。文生图就是完全用提示词文本去生成我们想要图片,但是很多时候会有词不达意的感觉。就像我们房子装修一样,我们只是通过文字描述很难表达出准确的想要的装修效果,如果能…

AD9371 官方例程裸机SW 和 HDL配置概述(二)

AD9371 系列快速入口 AD9371ZCU102 移植到 ZCU106 : AD9371 官方例程构建及单音信号收发 ad9371_tx_jesd -->util_ad9371_xcvr接口映射: AD9371 官方例程之 tx_jesd 与 xcvr接口映射 AD9371 官方例程 时钟间的关系与生成 : AD9371 官方…

stm32f103+HC-SR04+ssd1306实现超声波测距

🙌秋名山码民的主页 😂oi退役选手,Java、大数据、单片机、IoT均有所涉猎,热爱技术,技术无罪 🎉欢迎关注🔎点赞👍收藏⭐️留言📝 获取源码,添加WX 目录 前言HC…

Python自动化测试(1)-自动化测试及基本技术手段概述

生产力概述 在如今以google为首的互联网时代,软件的开发和生产模式都已经发生了变化, 在《参与感》一书提到:某位从微软出来的工程师很困惑,微软在google还有facebook这些公司发展的时候,为何为感觉没法有效还击&…

Spring:常见的面试题和答案

1、什么是 Spring 框架?Spring 框架有哪些主要模块? Spring 框架是一个为 Java 应用程序的开发提供了综合、广泛的基础性支持的 Java 平台。 Spring 帮助开发者解决了开发中基础性的问题,使得开发人员可以专注于应用程序的开发。 Spring 框架…

【MogDB/openGauss的三种函数稳定性关键字】

一、ORACLE中的类似的函数稳定性关键字(DETERMINISTIC) 在ORACLE里,function有着一个DETERMINISTIC参数,它表示一个函数在输入不变的情况下输出是否确定,只要输入的参数一样,返回的结果一定一样的&#xf…

MS35657步进电机驱动器可兼容DRV8824

MS35657 是一款双通道 DMOS 全桥驱动器,可以驱动一个步进电机或者两个直流电机。可兼容DRV8824(功能基本一致,管脚不兼容)。每个全桥的驱动电流在 24V 电源下可以工作到 1.4A。MS35657 集成了固定关断时间的 PWM 电流校正器&#…

STM8单片机在医疗设备中的应用和优势

STM8单片机作为一种高性能、低功耗的微控制器,在医疗设备领域得到了广泛的应用。本文对STM8单片机在医疗设备中的应用进行了研究,探讨了它在医疗设备中的优势和特点,并分析了其在提升医疗设备性能、精确控制和数据处理等方面的应用效果。 一…

Arrays.asList() 和 List.of() 的列表之争

1. 概述 有时在Java中,为了方便,我们需要创建一个小列表或将数组转换为列表。Java 为此提供了一些辅助方法。 在本文中,我们将比较初始化小型临时数组的两种主要方法:List.of()和 Array.asList()。 2. Arrays.asList() Java 自…

Java前后端分离的在线考试系统源码

Java前后端分离的在线考试系统源码 技术栈 1,SpringBoot 2,Mybatis-plus 3,MySQL 5.7 4,Vue全家桶 5,ElementUI 6,Redis 7,Swagger 8,阿里云OSS 9,Log4j 考…

Python模块导入出现ModuleNotFoundError: No module named ‘***’解决方法

概述 几年没弄python了,全部还会给老师,今天弄了个demo,老是报错,在此记录下,方便后续查阅。 环境:Windows10 开发IDEA:PyCharm 2023.1.3 1、报错如下所示 2、解决方法:安装execjs…

RLHF的替代算法之DPO原理解析:从Zephyr的DPO到Claude的RAILF

前言 本文的成就是一个点顺着一个点而来的,成文过程颇有意思 首先,如上文所说,我司正在做三大LLM项目,其中一个是论文审稿GPT第二版,在模型选型的时候,关注到了Mistral 7B(其背后的公司Mistral AI号称欧洲…

【技术干货】开源库 Com.Gitusme.Net.Extensiones.Core 的使用

目录 1、项目介绍 2、为项目添加依赖 3、代码中导入命名空间 4、代码中使用 示例 1:string转换 示例 2:object转换 1、项目介绍 Com.Gitusme.Net.Extensiones.Core是一个.Net扩展库。当前最新版本1.0.4,提供了常见类型转换&#xff0c…

【Java 进阶篇】Java Session 原理及快速入门

大家好,欢迎来到本篇博客。今天,我们将探讨Java Web开发中一个重要而令人兴奋的概念,即Session(会话)。Session是一种在Web应用程序中跟踪用户状态和数据的机制。我们将深入了解Session的原理,并通过示例来…

1688店铺所有商品数据接口(1688.item_search_shop)

1688店铺所有商品数据接口是一种允许开发者在其应用程序中调用1688店铺所有商品数据的API接口。利用这一接口,开发者可以获取1688店铺的所有商品信息,包括产品ID、SKU信息、价格、库存、图片等。这些数据可以用于构建各种业务场景,例如供应链…

腾讯云CVM服务器标准型S5、SA3、S6详细介绍

腾讯云CVM服务器标准型实例的各项性能参数平衡,标准型云服务器适用于大多数常规业务,例如:web网站及中间件等,常见的标准型云服务器有CVM标准型S5、S6、SA3、SR1、S5se等规格,腾讯云服务器网txyfwq.com来详细说下云服务…

[第二章—Spring MVC的高级技术] 2.1Spring MVC配置的替代方案

7.1.1 自定义DispatcherServlet配置 例如,在本章稍后的内容中(7.2节),我们将会看到如何在Spring MVC中处理multipart请求和文件上传。 如果计划使用Servlet 3.0对multipart配置的支持,那么需要使用DispatcherServlet的…

【移远QuecPython】EC800M物联网开发板调用网络API(使用SIM卡联网并调用高德地图API的定位坐标转换)

【移远QuecPython】EC800M物联网开发板调用网络API(使用SIM卡联网并调用高德地图API的定位坐标转换) 高德API使用方法: 文章目录 API相关配置SIM卡联网网络操作API调用 高德地图API产品介绍适用场景使用限制使用说明坐标转换 附录&#xff…

【源码解析】聊聊SpringBean是如何初始化和创建

我们知道通过类进行修复不同的属性,比如单例、原型等,而具体的流程是怎么样的呢,这一篇我们开始从源码的视角分析以下。 刷新方法 在刷新容器中有一个方法,其实就是 Bean创建的过程。 finishBeanFactoryInitialization(beanFact…