首先分别创建 a 表 和 b 表
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 代替。