MySQL三 | 多表查询

目录

多表查询

内连接

隐式内连接

显示内连接

外连接

左外连接

右外连接

自连接

子查询


多表查询

笛卡尔积:集合A和集合B的所有组合情况 A * B

在多表查询时应消除无效的笛卡尔积

内连接

查询的是两张表交集的地方

隐式内连接

sql 复制代码
SELECT 字段列表 FROM 表1,表2 WHERE 条件...;

显示内连接

sql 复制代码
SELECT 字段列表 FROM 表1 [INNER] JOIN 表2 ON 连接条件 ...;

外连接

左外连接

sql 复制代码
SELECT 字段列表 FROM 表一 LEFT [OUTER] JOIN 表二 ON 条件...;

左外连接相当于查询表1(左表)的所有数据 包含表一和表二交集部分的数据

右外连接

sql 复制代码
SELECT 字段列表 FROM 表二 RIGHT [OUTER] JOIN 表二 ON 条件...;

右外连接可以转换为左外连接

自连接

必须起别名

sql 复制代码
SELECT 字段列表 FROM 表A 别名A JOIN 表A 别名B ON 条件...;

自连接查询,可以是内连接查询,也可以是外连接查询

子查询

在sql语句中嵌套select语句,称为嵌套查询,又称为子查询

sql 复制代码
SELECT * FROM t1 WHERE column1 = (SELECT column1 FROM t2);

子查询外部可以是INSERT/UPDATE/DELETE/SELECT中的任意一个

|-------|--------------------------|
| 子查询类型 | 功能 |
| 标量子查询 | 子查询返回的结果是单个值(数字,字符串,日期等) |
| 列子查询 | 返回的结果是一列 |
| 行子查询 | 子查询返回的结果为一行 |
| 表子查询 | 返回的结果为多行多列 |

|--------|-------------------------|
| 常用操作符 | 功能 |
| IN | 在指定的集合范围内多选一 |
| NOT IN | 不在指定的范围内 |
| ANY | 子查询返回列表中,有任意一个满足即可 |
| SOME | 与ANY等同,使用SOME的地方都可以用ANY |
| ALL | 子查询返回列表的所有值都必须满足 |
| <> | 不等于 |

相关推荐
Lucifer三思而后行2 小时前
使用 BR 备份 TiDB 到 AWS S3 存储
数据库·tidb·aws
百***17073 小时前
Oracle分页sql
数据库·sql·oracle
qq_436962183 小时前
数据中台:打破企业数据孤岛,实现全域资产化的关键一步
数据库·人工智能·信息可视化·数据挖掘·数据分析
weixin_537765803 小时前
【数据库管理】MySQL主从复制详解
数据库·mysql
q***33374 小时前
数据库高安全—openGauss安全整体架构&安全认证
数据库·安全·架构
范纹杉想快点毕业4 小时前
《嵌入式开发硬核指南:91问一次讲透底层到架构》
java·开发语言·数据库·单片机·嵌入式硬件·mongodb
倚肆4 小时前
MySQL 配置文件属性详解
数据库·mysql
user_admin_god6 小时前
企业级管理系统的站内信怎么轻量级优雅实现
java·大数据·数据库·spring boot
百***22126 小时前
mysql的分区表
数据库·mysql
星光一影7 小时前
废品回收系统小程序源码
mysql·php·html5