SQL的多表连接查询

无关联多表查询,要分层通过where等过滤条件,and拼接多个条件,

select * from emp e,salgrade s 

where 

sal >

(select s.hisal from emp e,salgrade s where e.ename = 'smith' and e.sal between s.losal and s.hisal)

1)内联接:

   内联接使用比较运算符(使用像 =  或 <> 之类的比较运算符)根据每个表共有的列的值匹配两个表中的行,根据这两张表中相同列的条件,得出其      交集。例如:  检索 students和courses表中学生标识号相同的所有行。   

     有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行(链接表就是数据库在做查询形成的中间表

内连接:★这两个查询的结果是一样的。
格式1:显式的内连接
select a.*,b.* from a [inner] join b on ab的连接条件
格式2:隐式的内连接

select a.*,b.* from a,b where ab的连接条件

2)左向外联:

      是用的是LEFT  JOIN或LEFT OUTER JOIN     连接语句。

      根据两张表的关系(外键关联),笛卡尔过滤,也就是求出两张表的交集, 如果交集中,左边表的行, 在右边表中没有匹配,则该条记录左边表有数据, 右边表所有的字段都为null。

       左外连接时,写where语句的独立查询条件:  规则, on后面写连接条件, where后写查询条件  

[sql]  view plain  copy
  1. SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME  
  2. FROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID  
  3. WHERE O.ORDER_NUMBER<>'MIKE_ORDER001';  

3)右外连接:

      RIGHT  JOIN 或 RIGHT  OUTER  JOIN     连接语句

       和左外连接是相反的,查出的两张表的交集, 如果这条记录,右边表有数据,左边表没有, 则把左边表的字段都设置为null。

下面以SQL中的一个小Demo为例进行说明:

        SQL数据库中有两张表,一张人员(T_Person)表、一张卡(T_Card)表,人基本上都那么几张卡,像银行卡、饭卡、水卡、电费卡……

(T_Person)

(T_Card)

内连接

1.内连接(inner join 或 join)

        内连接是等值连接,它使用“=、>、<、<>”等运算符根据每个表共有的列的值匹配两个表中的行

查询语句:

[sql]  view plain  copy
  1.     select * from T_Person inner join T_Card on T_Person.CardId = T_Card.CardId  
查询结果:


外连接

2.左连接(left join 或 left outer join)

        左连接又称左向外连接,查询的结果集包括SQL语句中左表的所有行,右表中匹配的行。如果左表的某行在右表中没有匹配行,则用空值表示

查询语句:

[sql]  view plain  copy
  1.     select * from T_Person left join T_Card on T_Person.CardId = T_Card.CardId  
查询结果:


3.右连接(right join 或 right outer join)

        右连接也成右向外连接,查询的结果集包括SQL语句中右表的所有行,左表中匹配的行。如果右表的某行在左表中没有匹配的行,则用空值表示

查询语句:

[sql]  view plain  copy
  1.      select * from T_Person right join T_Card on T_Person.CardId = T_Card.CardId  
查询结果:


4.完全外连接(full join 或 full outer join)

        完全外连接,查询的结果集包括SQL语句中左表和右表的所有行。如果某行在另一个表中没有匹配行时,则用空值表示。

查询语句:

[sql]  view plain  copy
  1.      select * from T_Person full join T_Card on T_Person.CardId = T_Card.CardId  

查询结果:


总结:

        SQL中连接查询分内、外连接,外连接分左连接、右连接和完全外连接,它们的功能与视图差不多。其中左右连接查询是相对应的,即把连接类型和左表、右表互换位置就可得到相同的结果集。

SQL查询的基本原理:

1)单表查询:根据WHERE条件过滤表中的记录,然后根据SELECT的选择列选择相应的列进行返回最终结果。

 2)两表连接查询: 在on后面写连接条件, 在where后面写过滤的查询条件,然后再根据SELECT指定的列返回查询结果。

3)多表连接查询:先对第一个和第二个表按照两表连接做查询,然后用查询结果和第三个表做连接查询,以此类推,直到所有的表都连接上为止,最终形成一个中间的结果表,然后根据WHERE条件过滤中间表的记录,并根据SELECT指定的列返回查询结果。


关于on条件和where条件的区别:

ON条件:是过滤两个链接表笛卡尔积形成中间表的约束条件。

WHERE条件:ON只进行连接操作,WHERE只过滤中间表的记录。


对于连接类型的选择:  在实际运用中如果连接类型选择不当, 不但出现效率低并且可能还会出现逻辑的错误

1、 查两表关联列相等的数据用内连接

2、 Col_L是Col_R的子集时用右外连接。(左边表是右边表的子集,用右外)

3、 Col_R是Col_L的子集时用左外连接。(右边表是左边表的子集, 用左外)

4、 求差操作的时候用联合查询。


比如有三张表查询,student,teacher , project :(student中id,name,table2_id;
teacher 中id,name;
project 中id,name,table2_id;

  1. 第一种方法:select * from student,teacher,project where student.id=teacher.sid and student.id=project.sid;

  2. 第二种:select * from student inner join teacher on student.id=teacher.sid inner join project on student.id=project.sid;




猜你喜欢

转载自blog.csdn.net/yilaguandemei/article/details/79934772