2018-03-15面试之内连接、左连接
a表中有10条数据,b表中有5条数据,a表与b有关联的数据b中有3条,请问内连接查询时会有几条数据,左连接时会有几条数据?
a表 b表
test_id test_name user_id test_id user_name
1 test1 1 1 user1
2 test2 2 2 user2
3 test3 3 3 user3
以下省略7条数据 以下省略2条数据
内连接查询:
select t.* from t_test inner join t_user u on t.test_id=u.test_id;
结果:显示3条数据
原因:这是由于内连接会使用比较运算符根据每个表共有的值匹配两个表中的行。输出的数据为id相等的数据
左连接查询:
select t.* from t_test t left join t_user u on t.test_id=u.test_id;
结果:显示数据10条
原因:左向外连接的结果包括left join子句中指定的左表的所有行,而不仅仅是连接列所匹配的行。如果左表中的某行在右表中没有匹配行,则在相关联的结果集中右表的所有选择表均为空值。
以下内容均参考:https://www.cnblogs.com/afirefly/archive/2010/10/08/1845906.html
SQL的四种连接-左外连接、右外连接、内连接、全连接
1、内连接:内连接使用比较运算根据每个表共有的列的值匹配两个表中的行。例如students和courses表中学生标识号相同的行。只输出匹配的数据
2、外连接:
1.左连接(left join或left outer join)
左连接的结果集包括left join 子句中指定的左表的所有行,而不仅仅是连接所匹配的行,如果左表中的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表均为空值。
2.右连接(right join 或right outer join)
右连接是左连接的反向连接,将返回右表中所有的行。如果右表的某行在左表中没有匹配的行,则将左表返回空值
3.全连接(full join 或full outer join)
完整外部连接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表包含空值,如果表之间有匹配行,则整个结果集行包含基表的数据值。
3、交叉连接
交叉连接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉连接也称作笛卡尔积。
例子:
-------------------------------------------------
a表 id name b表 id job parent_id
1 张3 1 23 1
2 李四 2 34 2
3 王武 3 34 4
a.id同parent_id 存在关系
--------------------------------------------------
1) 内连接
select a.*,b.* from a inner join b on a.id=b.parent_id
结果是
1 张3 1 23 1
2 李四 2 34 2
2)左连接
select a.*,b.* from a left join b on a.id=b.parent_id
结果是
1 张3 1 23 1
2 李四 2 34 2
3 王武 null
3) 右连接
select a.*,b.* from a right join b on a.id=b.parent_id
结果是
1 张3 1 23 1
2 李四 2 34 2
null 3 34 4
4) 完全连接
select a.*,b.* from a full join b on a.id=b.parent_id
结果是
1 张3 1 23 1
2 李四 2 34 2
null 3 34 4
3 王武 null