MySQL查询(关联查询)

一、mysql查询与权限

(一)数据库关联查询

**内连接查询(inner join)**

查询两个表共有的数据,交集

SELECT * FROM tb1 INNER JOIN tb2 ON 条件

 

所有有宿舍的学员

 

左表查询(左关联查询)(left join)

查询两个表共有的数据,和左表所有的数据,左表有右表没有的部分用null代替

 

SELECT * FROM tb1 LEFT JOIN tb2 ON 条件

 所有学员的住宿情况

 

 

右表查询(右关联查询)(right join)

查询两个表共有的数据,和右表表所有的数据,右表有左表没有的部分用null代替
在这里插入图片描述

SELECT * FROM tb1 RIGHT JOIN tb2 ON 条件

 

 

所有宿舍的学员情况

在这里插入图片描述


没有学员的宿舍
在这里插入图片描述


没有宿舍的学员
在这里插入图片描述

 

 

(二)多表(三表)关联查询

1、内关联查询
查看所有php的课程

在这里插入图片描述

 

 

在这里插入图片描述

 

select * from major inner join major_course inner join course where 
major.id = major_course.major_id and major_course.course_id = course.id 
and major.id= 1;

 

 

在这里插入图片描述

 

规范写法:

复制代码
SELECT
m.id AS m_id,
m.name AS m_name,
c.id AS c_id,
c.name AS c_name
FROM
major AS m
INNER JOIN major_course AS mc
INNER JOIN course AS c
WHERE
m.id = mc.major_id
AND mc.course_id = c.id;
复制代码

 



2、关联子查询
查询所有含有计算机基础的专业

复制代码
SELECT
name
FROM
major
WHERE
id IN (
SELECT
mc.major_id
FROM
course AS c
LEFT JOIN major_course AS mc ON c.id = mc.course_id
WHERE
c.id = 1
);
复制代码

 

在这里插入图片描述

 

posted @   Python及时行乐  阅读(12077)  评论(0编辑  收藏  举报
编辑推荐:
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
阅读排行:
· C# 13 中的新增功能实操
· 万字长文详解Text-to-SQL
· Ollama本地部署大模型总结
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(4)
· 卧槽!C 语言宏定义原来可以玩出这些花样?高手必看!
点击右上角即可分享
微信分享提示