Mysql join连接查询的语法与示例

作者:卡尔特斯 时间:2024-01-15 07:34:48 

连接查询:

是将两个查询(或表)的每一行,以“两两横同对接”的方式,所得到的所有行的结果,即一个表中的某行,跟另一个表中的某行。进行“横向对接”,得到一个新行。

连接查询包括以下这些不同形式,连接方式:

交叉连接、内连接、外连接(分:左外连接,右外连接)

连接查询语法:

select * from 表名 [连接方式] join 表名 [on 连接条件] where ...;

测试数据:


mysql> select * from test;
+----+--------+------+------+
| id | name | sex | age |
+----+--------+------+------+
| 1 | name1 | 女 | 15 |
| 2 | name1 | 女 | 15 |
| 4 | name2 | 男 | 30 |
| 5 | name50 | 男 | 12 |
+----+--------+------+------+

mysql> select * from user;
+----+-------+------+
| id | name | age |
+----+-------+------+
| 1 | name1 | 18 |
| 2 | name2 | 15 |
| 3 | name3 | 20 |
| 4 | name4 | 30 |
+----+-------+------+

交叉连接 (cross join)

1、交叉连接其实可以认为是连接查询的“完全版本”, 即所有行都无条件地都连接起来。

2、关键字 “cross” 可以省略;

3、交叉连接又称为“笛卡尔积”,通常应用价值不大

语法形式:

select * from 表名, 表名;
select * from 表名 join 表名;
select * from 表名 cross join 表名;

规范的交叉连接写法


mysql> select * from test cross join user;
+----+--------+------+------+----+-------+------+
| id | name | sex | age | id | name | age |
+----+--------+------+------+----+-------+------+
| 1 | name1 | 女 | 15 | 1 | name1 | 18 |
| 2 | name1 | 女 | 15 | 1 | name1 | 18 |
| 4 | name2 | 男 | 30 | 1 | name1 | 18 |
| 5 | name50 | 男 | 12 | 1 | name1 | 18 |
| 1 | name1 | 女 | 15 | 2 | name2 | 15 |
| 2 | name1 | 女 | 15 | 2 | name2 | 15 |
| 4 | name2 | 男 | 30 | 2 | name2 | 15 |
| 5 | name50 | 男 | 12 | 2 | name2 | 15 |
| 1 | name1 | 女 | 15 | 3 | name3 | 20 |
| 2 | name1 | 女 | 15 | 3 | name3 | 20 |
| 4 | name2 | 男 | 30 | 3 | name3 | 20 |
| 5 | name50 | 男 | 12 | 3 | name3 | 20 |
| 1 | name1 | 女 | 15 | 4 | name4 | 30 |
| 2 | name1 | 女 | 15 | 4 | name4 | 30 |
| 4 | name2 | 男 | 30 | 4 | name4 | 30 |
| 5 | name50 | 男 | 12 | 4 | name4 | 30 |
+----+--------+------+------+----+-------+------+

直接使用 join 进行连接,相当于 cross join,默认就是 交叉连接


mysql> select * from test join user;

查询结果跟上面一致!!!

还可以直接 from 表,表... 也相当于是交叉连接


mysql> select * from test, user;

查询结果跟上面一致!!!

内连接 (inner join)

1、内连接其实是交叉连接的基础上,再通过 on 条件而筛选出来的部分数据。

2、关键字 "inner" 可以省略,但建议写上,真正有意义的是 on 连接条件。

3、内连接是应用最广泛的一种连接查询,其本质是根据条件筛选出“有意义的数据”。

语法形式:

select * from 表名 join 表名 on 连接条件;
select * from 表名 inner join 表名 on 连接条件;

查出两个表中 name 字段相等的数据


mysql> select * from test inner join user on test.name=user.name;
+----+-------+------+------+----+-------+------+
| id | name | sex | age | id | name | age |
+----+-------+------+------+----+-------+------+
| 1 | name1 | 女 | 15 | 1 | name1 | 18 |
| 2 | name1 | 女 | 15 | 1 | name1 | 18 |
| 4 | name2 | 男 | 30 | 2 | name2 | 15 |
+----+-------+------+------+----+-------+------+

查出两个表中 name 字段相等的数据,通过 as 给表取个别名进行使用


mysql> select * from test as t inner join user as u on t.name=u.name;

查询结果跟上面一致!!!

查出两个表中 name 字段相等,test 表中 age>15,user 表中 age>10 的数据

如果使用表中有重复的字段,那么就需要通过 [表名.字段名] 来使用,例如 age :


mysql> select * from test inner join user on test.name=user.name where test.age>15 and user.age>10;
+----+-------+------+------+----+-------+------+
| id | name | sex | age | id | name | age |
+----+-------+------+------+----+-------+------+
| 4 | name2 | 男 | 30 | 2 | name2 | 15 |
+----+-------+------+------+----+-------+------+

查出两个表中 name 字段相等,且 sex='男' 的数据。

如果使用表中没有重复的字段,那么可以通过 [表名.字段名] 或者直接使用 [字段名] 使用,例如 sex :


mysql> select * from test as t inner join user as u on t.name=u.name where t.sex='男';
mysql> select * from test as t inner join user as u on t.name=u.name where sex='男';
+----+-------+------+------+----+-------+------+
| id | name | sex | age | id | name | age |
+----+-------+------+------+----+-------+------+
| 4 | name2 | 男 | 30 | 2 | name2 | 15 |
+----+-------+------+------+----+-------+------+

外连接 - 左外连接 (left join)

1、左外连接其实是保证左边表的数据都能够取出的一种连接 。

2、左外连接其实是在内连接的基础上,再加上左边表中所有不能满足条件的数据

3、关键字 “outer" 可以省略。

语法形式:

select * from 表名 left [outer] join on 连接条件 where ...;

以左边的表为基准,保证左边表的数据全部显示,匹配不到的数据为 NULL


mysql> select * from test left join user on test.name=user.name;
+----+--------+------+------+------+-------+------+
| id | name | sex | age | id | name | age |
+----+--------+------+------+------+-------+------+
| 1 | name1 | 女 | 15 | 1 | name1 | 18 |
| 2 | name1 | 女 | 15 | 1 | name1 | 18 |
| 4 | name2 | 男 | 30 | 2 | name2 | 15 |
| 5 | name50 | 男 | 12 | NULL | NULL | NULL |
+----+--------+------+------+------+-------+------+

外连接 - 右外连接 (right join)

1、右外连接其实是保证右边表的数据都能够取出的一种连接 。

2、右外连接其实是在内连接的基础上,再加上右边表中所有不能满足条件的数据

3、关键字 “outer" 可以省略。

语法形式:

select * from 表名 right [outer] join on 连接条件 where ...;

以右边的表为基准,保证右边表的数据全部显示,匹配不到的数据为 NULL


mysql> select * from test right join user on test.name=user.name;
+------+-------+------+------+----+-------+------+
| id | name | sex | age | id | name | age |
+------+-------+------+------+----+-------+------+
| 1 | name1 | 女 | 15 | 1 | name1 | 18 |
| 2 | name1 | 女 | 15 | 1 | name1 | 18 |
| 4 | name2 | 男 | 30 | 2 | name2 | 15 |
| NULL | NULL | NULL | NULL | 3 | name3 | 20 |
| NULL | NULL | NULL | NULL | 4 | name4 | 30 |
+------+-------+------+------+----+-------+------+

来源:https://juejin.im/post/6881536621733380110

标签:mysql,join,连接
0
投稿

猜你喜欢

  • mysql 数据库死锁原因及解决办法

    2024-01-14 09:25:57
  • 14道基础Python练习题(附答案)

    2023-07-23 02:27:41
  • 基于python实现音乐播放器代码实例

    2022-07-17 21:55:53
  • vue实现全屏滚动效果(非fullpage.js)

    2024-05-28 15:46:00
  • 对Pycharm创建py文件时自定义头部模板的方法详解

    2022-06-05 15:24:06
  • 使用Python的datetime库处理时间(RPA流程)

    2023-04-23 22:53:15
  • Javascript 阻止javascript事件冒泡,获取控件ID值

    2023-07-02 05:25:57
  • JavaScript实现的反序列化json字符串操作示例

    2024-04-10 10:46:01
  • Python中使用Lambda函数的5种用法

    2022-07-13 17:07:35
  • 5个有效改进网页UI设计的技巧

    2008-12-19 12:04:00
  • Python实现PS滤镜碎片特效功能示例

    2021-04-25 01:35:31
  • python实现最小二乘法线性拟合

    2022-04-01 03:46:49
  • ​Python使用Mediapipe对图像进行手部地标检测

    2021-04-23 06:18:52
  • Jupyter Notebook运行代码无反应问题及解决方法

    2023-07-21 17:38:04
  • Python使用arrow库优雅地处理时间数据详解

    2023-02-26 07:14:12
  • pytorch + visdom CNN处理自建图片数据集的方法

    2023-05-03 06:33:16
  • PHP实现批量生成App各种尺寸Logo

    2023-07-23 03:59:59
  • 详细解析Webpack是怎么运行的

    2022-09-07 04:00:50
  • python生成器generator:深度学习读取batch图片的操作

    2022-07-31 08:43:06
  • 用python下载百度文库的代码

    2023-07-31 00:40:44
  • asp之家 网络编程 m.aspxhome.com