MySQL 连表操作

首先分别创建 a 表 和 b 表

a 表

b 表

内连接

内连接 语法: a inner join b ;
一般 inner 可以省略不写,也就是:

select  *  from  a  join  b ;

像这样不加查询条件会形成 笛卡尔积 。
笛卡尔积的意思是:是指包含两个集合中任意取出两个元素构成的组合的集合。// 两表分别交叉查询了一遍;
即(a表3行 x b表3行 = 结果集 9 行数据)
也可以加上条件查询条件 on 或者 using ,两者的区别在于 都是查询出符合条件的结果集 ,但是using会优化掉相同的字段。

 select  *  from  a  join  b  on  a.id = b.id ;

从上图可以看出,加上条件之后,只查询出了符合条件的结果集

 select  *  from  a  join  b  on  using(id) ;

从上图可以看出,同样是查询出了符合条件的结果集,但是相同的字段 id 被using优化了。

外连接

外连接又分为:左外连接(左连接)、右外连接(右连接)、全外连接
注:外连接必须要添加 on 或者 using 作为查询条件,否则会报语法错误;

左连接 语法:a left outer join b ;
一般outer可以省略不写。比如:

select * from a left join b on a.id = b.id ;

看上图显示:左连接既 左边 a 表作为基表(主表)显示所有行, b 表作为外表 条件匹配上的就显示,没匹配上的就用 Null 填充;

右连接 语法:a right outer join b ;
一般outer可以省略不写。比如:

select * from a right join b on a.id = b.id ;

看上图显示:右连接即 右边 b 表作为基表(主表)显示所有行, a 表作为外表 条件匹配上的就显示,没匹配上的就用 Null 填充; 和左连接相反。

全外连接

经查找发现 MySQL 是不支持所谓 a full join b 语作为 全外连接查询的,想要实现全外连接查询可以通过 union 实现,union 操作符用于合并两个或多个 SELECT 语句的结果集,语句如下:

select * from a left join b on a.id = b.id  union  select * from a right join b on a.id = b.id ;


注:当 union 和 all 一起使用时(即 union all ),重复的行不会去除。

交叉连接

交错连接 语法:a cross join b ;交错连接可以加查询条件,也可以不加查询条件,如果不加查询条件会形成 笛卡尔积,类似内连接效果,同样可以使用 using 语句优化字段。

select * from a cross join b ;

加上条件查询:

select * from a cross join b on a.id = b.id ;

总结:
1、内连接和交叉连接类似,只是语句语法有所不同,但最后查询出来的结果集的效果都是一样的,添加条件查询就只查询匹配条件的行,不添加条件查询则形成 笛卡尔积 而降低效率。
2、左外连接以左边表为基础表 显示所有行 ,右边表条件匹配的行显示,不匹配的则有 Null 代替。
3、右外连接以右边表为基础表 显示所有行 ,左边表条件匹配的行显示,不匹配的则有 Null 代替。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容