MySQL连接查询
MySQL连接查询
在多表联合查询时,为了减少查询的次数,使用连接查询可以一次查询多个相关联表的数据。
MySQL连接查询:分为内连接查询和外连接查询。
其中外连接查询又分成 left连接查询 和 right连接查询。
下午为两张数据库表,表1和表2。
- 查询两张表相交的数据,使用内连接查询,如红色区域的相交数据,可使用内连接进行查询。
- 查询两张表不相交的数据使用外连接,如表1中与表2不相交的区域即蓝色区域使用
left连接查询。 - 表2中与表1不相交的区域,即绿色区域,使用
right连接查询

建立数据表
使用背景:学生成绩管理系统,包含学生表(student)、课程表(course)、考试表(exam)等三种表,表的关系如下所示

首先创建三种表的结构
CREATE TABLE student (
uid INT UNSIGNED PRIMARY KEY NOT NULL AUTO_INCREMENT,
name VARCHAR(50) NOT NULL,
age TINYINT UNSIGNED NOT NULL,
sex ENUM('M','W') NOT NULL);CREATE TABLE course (
cid INT UNSIGNED PRIMARY KEY NOT NULL AUTO_INCREMENT,
cname VARCHAR(50) NOT NULL,
credit TINYINT UNSIGNED NOT NULL);CREATE TABLE exame (
uid INT UNSIGNED NOT NULL,
cid INT UNSIGNED NOT NULL,
time DATE NOT NULL,
score FLOAT NOT NULL,
PRIMARY KEY(uid,cid));
向数据表中添加数据
insert into student(name,age,sex) values
('zhangsan', 18, 'M'),
('gaoyang', 20, 'w'),
('chenwei', 22, 'M'),
('linfeng', 21, 'W'),
('liuxiang', 19, 'W');insert into course(cname,credit) values
('c++基础课程', 5),
('c++高级课程', 10),
('c++项目开发', 8),
('c++算法课程', 12);insert into exame(uid,cid,time,score) values
(1,1,'2021-04-09', 99.0),
(1,2,'2021-04-10', 80.0),
(2,2,'2021-04-10', 90.0),
(2,3,'2021-04-12', 85.0),
(3,1,'2021-04-09', 56.0),
(3,2,'2021-04-10', 93.0),
(3,3,'2021-04-12', 89.0),
(3,4,'2021-04-11', 100.0),
(4,4,'2021-04-11', 99.0),
(5,2,'2021-04-10', 59.0),
(5,3,'2021-04-12', 94.0),
(5,4,'2021-04-11', 95.0);
SQL内连接(inner join)
两个表的内连接查询
select a.uid,a.name,a.age,a.sex from student a where a.uid=1;
select c.score from exame c where c.uid=1 and c.cid=2;
// 从 student 小表中取出所有的a.uid 然后拿着这些 uid 在exame大表中搜索
select a.uid,a.name,a.age,a.sex from student a
inner join exame c on a.uid=c.uid
where c.uid=1 and c.cid=2;
三个表的内连接查询
select a.uid,a.name,a.age,a.sex,b.cid,b.cname,b.credit,c.score
from exame c
inner join student a on c.uid=a.uid
inner join course b on c.cid=b.cid
where c.uid=1 and c.cid=2;
- 区分大表和小表,按照选择的数据量来区分,而不是整表的数据量。小表永远是整表扫描,然后去大表搜索,一般在大表中创建索引。例:从exam大表中取出所有的c.uid和c.cid,然后拿着这些uid和cid去student和course小表中整表扫描
- 可结合分组、排序操作,进行更精确的搜索
- 先执行on连接产生临时表,再执行where在临时表中筛选符合条件的数据
- 对于inner join内连接,过滤条件写在where的后面和on连接条件里面,效果是一样的。
结合limit分页优化SQL语句
select a.id,a.email,a.passward from t_user a inner join(select id from t_user limit 150000,10) b on a.id=b.id;
在mysql中创建一个临时表作为小表,提升SQL效率
SQL外连接(outer join)
SQL左连接查询(left join)
把left这边的表所有数据显示出来,在右表中不存在相应数据,则显示NULL
SELECT a.属性名列表,b.属性名列表 FROM table_name1 a LEFT JOIN table_name2 b on a.id=b.id;
select a.*,b.* from student a left outer join exame b on a.uid=b.uid;
SQL右连接查询(right join)
把right这边的表所有数据显示出来,在左表中不存在相应数据,则显示NULL
select a.*,b.* from student a left outer join exam b on a.uid=b.uid;
实际应用场景:查询在当前连接中为空的属性
select a.* from student a left join exam b on a.uid=b.uid where b.cid is null;
// not in 对于索引的命中并不高,推荐使用外连接
select * from student where uid not in (select distinct uid from exam);
对于outer join外连接,在判断null和限制条件的情况下,限制条件写在on里面,where条件过滤只判断null的情况
select a.* from student a left join exam b on a.uid=b.uid and b.cid=3 where b.cid is null;
相关文章:
MySQL连接查询
MySQL连接查询 在多表联合查询时,为了减少查询的次数,使用连接查询可以一次查询多个相关联表的数据。 MySQL连接查询:分为内连接查询和外连接查询。 其中外连接查询又分成 left连接查询 和 right连接查询。 下午为两张数据库表,表…...
7. Docker——Dockerfile
本章讲解知识点 DockerfileDockerfile 常用命令Dockerfile 综合示例Docker Compose当我们理解了镜像的基本原理后,我们就可以开始 Dockerfile 的学习了。 1. Dockerfile Dockerfile 是用于构建 Docker 镜像的脚本。它包含一组指令,按顺序执行以创建 Docker 镜像,从而使其可…...
Input事件在应用中的传递(一)
Input事件在应用中的传递(一) hongxi.zhu 2023-4-25 前面我们已经梳理了input事件在native层的传递,这一篇我们接着探索input事件在应用中的传递与处理,我们将按键事件和触摸事件分开梳理,这一篇就只涉及按键事件。 一、事件的接收 从前面的…...
我在VScode学Java(Java一维数组)
我的个人博客主页:如果\真能转义1️⃣说1️⃣的博客主页 关于Java基本语法学习---->可以参考我的这篇博客:(我在Vscode学Java) 我在VScode学Java(Java一维数组) Java 一维数组 声明数组:先声明,后使用 动态分配内…...
不能使用chatGPT?这3个平替甚至比chatGPT更强
不能使用chatGPT?这3个平替甚至比chatGPT更强 chatGPT,一款由OpenAI开发的新型AI聊天机器人,正在势如破竹地改变着许多人的工作和生活方式。作为一款基于大语言模型的聊天机器人,chatGPT能够理解自然语言并进行人机对话。与传统的…...
基于SLM调制器,MIT研发高效率全息显示方案
此前,青亭网曾报道过NVIDIA、三星、剑桥大学等对空间光调制器(SLM)全息方案的探索。空间光调制器可调节光波的空间分布,在电驱动信号控制下,可改变光在空间中传播的振幅、强度、相位、偏振态等特性,从而形成…...
【Docker】镜像与docker数据卷
文章目录 一、镜像1、镜像2、镜像原理之联合文件系统3、镜像原理之分层4、commit镜像 二、数据卷1、数据卷2、-v使用数据卷3、实战:MySQL 同步数据4、docker volume相关指令5、匿名和具名挂载6、数据卷之Dockerfile7、数据卷容器 一、镜像 1、镜像 镜像是一种轻量级…...
机器学习小结之KNN算法
文章目录 前言一、概念1.1 机器学习基本概念1.2 k 值1.3 距离度量1.4 加权方式 二、实现2.1 手写实现2.2 调库 Scikit-learn2.3 测试自己的数据 三、总结3.1 分析3.2 KNN 优缺点 参考 前言 KNN (K-Nearest Neighbor)算法是一种最简单,也是一个很实用的机器学习的…...
函函函函函函函函函函函数——two
🤩本文作者:大家好,我是paperjie,感谢你阅读本文,欢迎一建三连哦。 🥰内容专栏:这里是《C知识系统分享》专栏,笔者用重金(时间和精力)打造,基础知识一网打尽,…...
SpringCloud学习笔记06
九十五、Cloud Alibaba简介 0、why会出现SpringCloud alibaba Spring Cloud Netflix项目进入维护模式 1、是什么 官网:spring-cloud-alibaba/README-zh.md at 2.2.x alibaba/spring-cloud-alibaba GitHub 2、能干嘛 3、去哪下 spring-cloud-alibaba/README-…...
学系统集成项目管理工程师(中项)系列14_采购管理
1. 概念和术语 1.1. 采购是从项目团队外部获得产品、服务或成果的完整的购买过程 1.2. 三大类 1.2.1. 工程 1.2.2. 产品/货物 1.2.3. 服务 2. 主要过程 2.1. 编制采购管理计划 2.2. 实施采购 2.3. 控制采购 2.4. 结束采购 3. 合同 3.1. 包括买方和卖方之间的法律文…...
PMP课堂模拟题目及解析(第3期)
21. 一家农业设备制造商因一个缺陷部件而召回数千个产品。这个问题导致许多客户不满,公司花费 500 万美元来修理和更换零件。哪一种成本预算类型可以防止这个问题? A. 非一致性成本 B. 一致性成本 C. 矩阵图 D. 多标准决策分析 22. 一位团队成员…...
华为OD机试 - 微服务的集成测试( Python)
题目描述 现在有n个容器服务,服务的启动可能有一定的依赖性(有些服务启动没有依赖),其次服务自身启动加载会消耗一些时间。 给你一个 n x n 的二维矩阵useTime,其中 useTime[i][i]=10 表示服务i自身启动加载需要消耗10s useTime[i][j] = 1 表示服务i启动依赖服务j启动完…...
SLAM面试笔记(4) — 企业面试汇总
目录 1 大疆 一面(50min) 二面(30min) 三面(30min) 2 华为 一面(30min) 二面(30min) 三面(30min) 3 海康 一面(…...
五大新兴产业中,有三个中国出口全球占比居首-机器视觉工程师正处于需求旺盛阶段
五大新兴产业包含生物保健和电动汽车,新一代半导体、新一代显示器、二次电池。 在五大新兴产业中的三大领域——新一代半导体、新一代显示器、二次电池,中国对外出口在全球所占比重最高。 电动汽车,汽车行业一直对机器视觉工程师有着强烈的需求,无论比亚迪,特斯拉等等…...
网络安全监管
网络安全监管 网络安全法律体系建设计算机犯罪、信息安全等基本概念我国立法体系及网络安全法我国的立法体系网络安全法出台背景基本概念安全法主要结构第一章 总则第二章 网络安全支持与促进第三章 网络运行安全第四章 网络信息安全第五章 监测预警与应急处置第六章 法律责任 …...
【code review】代码评审的18个军规(建议收藏)
文章目录 背景1. 添加必要的注释2.日志打印规范3. 命名规范4.参数校验5. 判空处理6. 异常处理规范7. 模块化,可扩展性8. 并发控制规范9. 单元测试规范10. 代码格式规范11. 接口兼容性12. 程序逻辑是否清晰,主次是否够分明13. 安全规范14. 事务控制规范15. 幂等处理规…...
PyQt5桌面应用开发(5):对话框
本文目录 PyQt5桌面应用系列对话框QDialogQDialog的基本用法按钮组 QMessageBox综合展示的例子结论 PyQt5桌面应用系列 PyQt5桌面应用开发(1):需求分析 PyQt5桌面应用开发(2):事件循环 PyQt5桌面应用开发&a…...
整洁的代码
文章目录 为什么要写整洁的代码什么是整洁的代码可读性运行效率扩展性 怎么写整洁的代码注释&命名函数&类代码结构 为什么要写整洁的代码 为什么要写整洁的代码,回答这个问题之前,也许应该想想写糟糕的代码的原因 是想快点完成吗?还是要赶时间吗?有可能.或许你觉得…...
Redis集群常用命令及说明
一、集群的特点 1、集群架构特点 (1)所有的redis节点彼此互联(PING-PONG机制),内部使用二进制协议优化传输速度和带宽; (2)节点的fail是通过集群中超过半数的节点检测失效时才生效…...
73.人工智能实战:LLM 调用超时怎么治理?从前期发现偶发慢请求到 Timeout、Retry、Backoff 与幂等设计
人工智能实战:LLM 调用超时怎么治理?从前期发现偶发慢请求到 Timeout、Retry、Backoff 与幂等设计 一、问题场景:接口偶尔超时,不是大问题?上线后变成雪崩 大模型服务上线后,很多团队都会遇到: 偶发超时。一开始比例很低: 1000次请求里有3次超时大家可能觉得问题不大…...
一次 read() 背后的 3000 个 CPU 周期——从 SYSCALL到 io_uring 零系统调用,拆解系统调用开销的三层优化
在你的 Linux 服务器上跑一条 perf stat -e cycles -e instructions ./getpid_loop,你会看到一个让人不安的数字:一次什么都不做的 getpid() 系统调用——内核只是从 current->tgid 读一个整数然后返回——在开启 KPTI 的现代内核上消耗了大约 2500–4000 个 CPU 周期,而…...
hermes agent工具如何对接taotoken多模型聚合平台
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 Hermes Agent 工具如何对接 Taotoken 多模型聚合平台 Hermes Agent 是一款功能强大的 AI 代理开发框架,支持通过自定义…...
在VS Code中集成Cppcheck与MISRA-C:打造实时嵌入式代码质量守护
1. 为什么嵌入式开发需要实时代码检查 在嵌入式开发中,尤其是涉及汽车电子、工业控制等领域时,代码质量直接关系到产品的安全性和可靠性。我曾经参与过一个车载控制器的项目,团队在开发后期进行静态检查时,发现了上百个MISRA-C违规…...
MRIcroGL深度指南:医学影像三维可视化的终极开源解决方案
MRIcroGL深度指南:医学影像三维可视化的终极开源解决方案 【免费下载链接】MRIcroGL v1.2 GLSL volume rendering. Able to view NIfTI, DICOM, MGH, MHD, NRRD, AFNI format images. 项目地址: https://gitcode.com/gh_mirrors/mr/MRIcroGL MRIcroGL是一款专…...
怎样免费解锁12种加密音乐格式:开源工具完整使用指南
怎样免费解锁12种加密音乐格式:开源工具完整使用指南 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web 项目地址: https:…...
Tinke:免费解锁NDS游戏资源的终极指南
Tinke:免费解锁NDS游戏资源的终极指南 【免费下载链接】tinke Viewer and editor for files of NDS games 项目地址: https://gitcode.com/gh_mirrors/ti/tinke 你是否曾经好奇任天堂NDS游戏内部的神秘世界?想要提取游戏中的精美图片、动听音乐或…...
具身单月狂揽了200亿?!
点击下方卡片,关注“具身智能之心”公众号具身智能领域的投资人,现在大概是全中国最焦虑、也最亢奋的一群人。刚刚过去的4月,这个赛道丢下了两颗足以震动行业的“深水炸弹”:它石智航官宣完成4.55亿美金Pre-A轮融资,一…...
给SATA硬盘下命令:从Non-Data到DMA Queued,12类命令的实战图解与抓包分析
深入解析SATA硬盘12类命令:从Non-Data到DMA Queued的实战指南 在存储系统的底层交互中,SATA协议扮演着至关重要的角色。对于嵌入式开发工程师和存储系统测试人员而言,理解SATA命令层的运作机制不仅有助于调试硬件问题,更能优化存储…...
Python Flask应用如何实现用户画像分析_记录用户行为与分析数据
关键在于异步解耦:行为日志先入内存队列或Redis,由独立worker批量落库;统一用持久visitor_id绑定用户行为,避免ID断链;标签采用宽表关联表双层结构,支持高效查询与灵活迭代。Flask 中怎么记录用户行为而不拖…...
