我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL中怎么实现左连接和右连接

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL中怎么实现左连接和右连接

今天就跟大家聊聊有关MySQL中怎么实现左连接和右连接,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

以MySql为例。在MySQL数据库中建立两张数据表,并分别插入一些数据。

示例脚本如下:

 drop table table1;   CREATE TABLE `andrew`.`table1`   (   `name` VARCHAR(32) NOT NULL,   `city` VARCHAR(32) NOT NULL   )   ENGINE = MyISAM;   insert into TABLE1(name, city) values ('Person A', 'BJ');   insert into TABLE1(name, city) values ('Person B', 'BJ');   insert into TABLE1(name, city) values ('Person C', 'SH');   insert into TABLE1(name, city) values ('Person D', 'SZ');   commit;   drop table table2;   CREATE TABLE `andrew`.`table2`   (   `name` VARCHAR(32) NOT NULL,   `city` VARCHAR(32) NOT NULL   )   ENGINE = MyISAM;   insert into TABLE2(name, city) values ('Person W', 'BJ');   insert into TABLE2(name, city) values ('Person X', 'SH');   insert into TABLE2(name, city) values ('Person Y', 'SH');   insert into TABLE2(name, city) values ('Person Z', 'NJ');   commit;

1. MySQL外连接 – 左连接结果

table1居左,故谓之左连接。这种情况下,以table1为主,即table1中的所有记录均会被列出。有一下三种情况:

a. 对于table1中的每一条记录对应的城市如果在table2中也恰好存在而且刚好只有一条,那么就会在

返回的结果中形成一条新的记录。如上面Person A和Person B对应的情况。

b. 对于table1中的每一条记录对应的城市如果在table2中也恰好存在而且有N条,那么就会在返回的结果中形成N条新的记录。如上面的Person C对应的情况。

c. 对于table1中的每一条记录对应的城市如果在table2中不存在,那么就会在返回的结果中形成一条

条新的记录,且该记录的右边全部NULL。如上面的Person D对应的情况。

不符合上面三条规则的记录不会被列出。

2. MySQL外连接 – 右连接结果

table2居右,故谓之右连接。这种情况下,以table2为主,即table2中的所有记录均会被列出。有一下三种情况:

a. 对于table2中的每一条记录对应的城市如果在table1中也恰好存在而且刚好只有一条,那么就会在

返回的结果中形成一条新的记录。如上面Person X和Person Y对应的情况。

b. 对于table2中的每一条记录对应的城市如果在table1中也恰好存在而且有N条,那么就会在返回的结果中形成N条新的记录。如上面的Person W对应的情况。

c. 对于table2中的每一条记录对应的城市如果在table1中不存在,那么就会在返回的结果中形成一条

条新的记录,且该记录的左边全部NULL。如上面的Person Z对应的情况。

不符合上面三条规则的记录不会被列出。

3. MySQL内连接

MySQL内连接的数据记录中,不会存在字段为NULL的情况。可以简单地认为,内链接的结果就是在左连接或者右连接的结果中剔除存在字段为NULL的记录后所得到的结果。甚至可以认为,如果两个表中仅分别剩下内连接运算后所得的数据记录,如table1中只有Person A、Person B和Person C,table2中只有Person W、Person X和Person Y,那么这两个表的之间的左连接和右连接的返回的结果是一样的。

注意:select * from table1 a inner join table2 b on a.city = b.city 和select * from table1 a join table2 b on a.city = b.city 的效果是一样的,即如果join的左边没有诸如left、right或者inner这样的关键字时,缺省的是内连接。另外,MySQL不支持full join。

看完上述内容,你们对MySQL中怎么实现左连接和右连接有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL中怎么实现左连接和右连接

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL左连接、右连接、内连接与Hash连接怎么实现

这篇“MySQL左连接、右连接、内连接与Hash连接怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL左连接、
2022-11-30

mysql中内连接,左连接和右连接的区别

mysql 中内连接、左连接和右连接的区别在于:内连接只返回同时在两个表中匹配的行,而左连接返回左表所有行,包含匹配右表行,右连接返回右表所有行,包含匹配左表行。内连接语法:select * from table1 inner join t
mysql中内连接,左连接和右连接的区别
2024-04-29

mysql 实现表连接(左,右,内,全连接)【转】

查询中出现两个表的连接,下面通过实例来讲解一下各种连接查询的不同之处表 a,和表b 如下图a 表中 有 abcd b表中有 abcf内连接:SELECT * from a INNER JOIN b on a.name=b.id;得出结果 如图,选择等值的结果(
mysql 实现表连接(左,右,内,全连接)【转】
2021-11-03

mysql左连接和右连接有什么区别

本篇文章为大家展示了mysql左连接和右连接有什么区别,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、区别左连接,以左表为参照,显示所有数据,右表中没有则以null显示右连接,以右表为参照显示数据
2023-06-14

sql中的左连接和右连接是什么

sql 中的左连接和右连接是两种连接表的方式:左连接:保留左表所有行,即使右表没有匹配行,右表字段为空。右连接:保留右表所有行,即使左表没有匹配行,左表字段为空。SQL 中的左连接和右连接在 SQL 中,连接是将来自两个或更多表的行组合在
sql中的左连接和右连接是什么
2024-05-10

sql中左连接和右连接有什么区别

在SQL中,左连接(LEFT JOIN)和右连接(RIGHT JOIN)是连接两个表的一种方式,它们的区别在于连接的方向和结果集的形式。左连接(LEFT JOIN)是指从左表中取出所有记录,并且如果右表中与左表中的记录有匹配的记录,则将其
2023-10-23

sql中的左连接和右连接的区别

sql 中左连接和右连接的区别在于优先连接的表:左连接优先连接左表,而右连接优先连接右表。因此,当处理包含 null 值的表时,左连接将确保返回左表中的所有行,而右连接将确保返回右表中的所有行,即使在另一表中没有匹配行时也会如此。SQL 中
sql中的左连接和右连接的区别
2024-05-10

sql中的左连接和右连接的关系

在 sql 中,左连接和右连接是两种联接类型:左连接优先显示左表中的所有行,匹配行显示右表数据,不匹配行为 null。右连接优先显示右表中的所有行,匹配行显示左表数据,不匹配行为 null。SQL 中左连接和右连接的关系在 SQL 中,左
sql中的左连接和右连接的关系
2024-05-10

sql中左连接与右连接的区别

sql 中左连接和右连接主要区别在于连接结果中优先显示哪个表的数据。左连接优先显示左表,若右表无匹配行则填充 null;右连接优先显示右表,若左表无匹配行则填充 null。SQL 中左连接与右连接的区别在 SQL 中,左连接和右连接是连接
sql中左连接与右连接的区别
2024-05-10

编程热搜

目录