当前位置:Gxlcms > 数据库问题 > SQL JOIN

SQL JOIN

时间:2021-07-01 10:21:17 帮助过:8人阅读

),接下来我们就一起来了解SQL中的JOIN.

   技术分享

  

1、什么是JOIN?


   Join是关系型数据库系统的重要操作之中的一个,SQL Server中包括的经常使用Join:内联接、外联接和交叉联接等,Join用于依据两个或者多个表中的列之间的关系。从这些表中查询数据。

 技术分享

 

2、怎么使用JOIN?


 新建两张表作为样例,表例如以下

技术分享     技术分享

 

●INNER JOIN


  SQL语句

select * from T_NumA inner join T_NumB on T_NumA.aID=T_NumB.bID

    结果例如以下

  技术分享                     技术分享

  执行的结果是得到两个表之间的交集。用右边的图能够看出,Inner join符合交换律:“A inner join B”,“B inner join A”一样。


 ●OUTER JOIN

 1)、LEFT(OUTER)JOIN和RIGHT(OUTER)JOIN

   SQL语句

 

select * from T_NumA left outer join T_NumB on T_NumA.aID=T_NumB.bID

select * from T_NumA right outer join T_NumB on T_NumA.aID=T_NumB.bID

执行结果

  LEFT:

  技术分享                    技术分享

  执行的结果:产生表A的全然集。而B表中匹配的则有值。没有匹配的则以null值代替。

  RIGHT:

  技术分享       

  从执行的结果一眼就能够看出来。该联接产生表B的全然集,而A表中匹配的则有值。没有匹配的则以null值代替。

  

 2)、FULL(OUTER)JOIN

  SQL语句

select * from T_NumA full outer join T_NumB on T_NumA.aID=T_NumB.bID

执行结果:

 技术分享                   技术分享

 

 由结果可知:该联接产生A和B的并集。

可是须要注意的是,对于没有匹配的记录。则会以null做为值。


 ●CROSS JOIN

 SQL语句

select * from T_NumA cross join T_NumB 

执行结果:

 技术分享

 由执行结果可知:交叉联接执行的结果就是咱们在数据库系统原理中学的笛卡尔积(Cartesian Product),产生一个6*6=36行记录的结果集。


3、结束语

 本文章所讲的联接语句都是将不同表的列进行纵向拼接。由于在做机房收费系统个人重构的时候,仅仅涉及到纵向拼接表的查询,有纵向,那么肯定也有横向。横向拼接也有多种方式:Not in,Union和Intersect,这里仅仅做简介。Not in是去两个结果集的差集。Union是两个集合的并集,会自己主动删除反复的记录。也能够用Union All来保留全部记录行。

Intersect是两个集合的交集,即同一时候存在于两个集合中的记录。

 假设有什么不妥的地方。欢迎各位博友斧正!!

  

  


      

   

SQL JOIN

标签:sql语句   数据   div   blog   term   数据库   中学   笛卡尔   inner   

人气教程排行