MySQL数据库中的多表查询

  • 什么是多表查询?

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

我们先创建一个表格

MySQL数据库中的多表查询

并且插入数据

MySQL数据库中的多表查询

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

select * from user_info

MySQL数据库中的多表查询

select * from address 

MySQL数据库中的多表查询

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

  •  内连接(inner join)

①显式等值连接:

MySQL数据库中的多表查询

②隐式等值连接:

 

MySQL数据库中的多表查询

 执行结果

MySQL数据库中的多表查询

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

  • 外连接(outer join)

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

MySQL数据库中的多表查询

这时执行结果一样

 MySQL数据库中的多表查询

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

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

  • 交叉连接(cross join)

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

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

MySQL数据库中的多表查询

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

上一篇:Docker


下一篇:mysql查询两个日期中间的所有日期