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

原文地址:https://www.cnblogs.com/kongnengjing/p/8577241.html