MySQL数据库中的多表查询

  • 什么是多表查询?

多个表的关联查询即多表查询,而多个表关联查询需要依据多表之间列关系将其连接起来,这种连接方式分为三种:内连接(inner join)、外连接(outer join)及交叉连接(cross join)

我们先创建一个表格

并且插入数据

 然后使用单表查询来查询数据

select * from user_info

select * from address 

在这里插入图片描述

单表查询固然快捷,但如果两张表的数据有关联时,需要查询其共同数据时便需要多表查询。

  •  内连接(inner join)

①显式等值连接:

②隐式等值连接:

 

 执行结果

可以看到,两表之间的共同数据被查询出来,因此内连接往往用于查询表之间的共同数据

  • 外连接(outer join)

分为左外连接、右外连接、全连接(MySQL数据库不支持全连接)

这时执行结果一样

 在这里插入图片描述

 因为:①如果是right , 则 right右边是主表,左边是从表,将主表数据全部显示出来,哪怕是从表没有的数据
            ②如果是left , 则 left左边是主表,右边是从表,将主表数据全部显示出来,哪怕是从表没有的数据

上面的连接代码中实际上主从表并没有改变,因此执行结果一样。

  • 交叉连接(cross join)

左表(“cross join”关键字左边的表)中的每一行与右表(“cross join”关键字右边的表)中的所有行组合,交叉联接的结果是一个笛卡尔积。

select ui.*,addr.* from user_info ui cross join address addr;

在这里插入图片描述

没有太大的意义,一般不使用。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值