left join (左连接):返回包括左表中的所有记录和右表中连接字段相等的记录。
左连(左表加公共):select*from t1 left join t2 on t1.##=t2.##
right join (右连接):返回包括右表中的所有记录和左表中连接字段相等的记录。
右连(右表加公共):select*from t1 right join t2 on t1.##=t2.##
inner join (等值连接或者叫内连接):只返回两个表中连接字段相等的行。
内连接:select*from t1 corss t2 on t1.##=t2.##
full join (全外连接):返回左右表中所有的记录和左右表中连接字段相等的记录。
全外连:select*from t1 full join t2 on t1.##=t2.##
cross join (交叉连接 ):没有 WHERE 子句的交叉联接将产生连接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。
交叉连:(笛卡尔积):select*from t1 corss join t2 where t1.##=t2.##
举个例子:
A表
id name
1 小王
2 小李
3 小刘
B表
id A_id job
1 2 老师
2 4 程序员
内连接:(只有2张表匹配的行才能显示)
select a.name,b.job from A a inner join B b on a.id=b.A_id
只能得到一条记录
小李 老师
左连接:(左边的表不加限制)
select a.name,b.job from A a left join B b on a.id=b.A_id
三条记录
小王 null
小李 老师
小刘 null
右连接:(右边的表不加限制)
select a.name,b.job from A a right join B b on a.id=b.A_id
两条记录
小李 老师
null 程序员
全外连接:(左右2张表都不加限制)
select a.name,b.job from A a full join B b on a.id=b.A_id
四条数据
小王 null
小李 老师
小刘 null
null 程序员
交叉连接:(笛卡尔积)
