-
什么是多表查询?
多个表的关联查询即多表查询,而多个表关联查询需要依据多表之间列关系将其连接起来,这种连接方式分为三种:内连接(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;
没有太大的意义,一般不使用。