关于多表查询sql常用的连接语句:左外连接、右外连接、内连接
2016-08-10 10:04
260 查看
1)内联接:
内联接使用比较运算符(使用像
= 或 <> 之类的比较运算符)根据每个表共有的列的值匹配两个表中的行,根据这两张表中相同列的条件,得出其 交集。例如: 检索 students和courses表中学生标识号相同的所有行。
有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行(链接表就是数据库在做查询形成的中间表)。
隐式的内连接:
没有INNER
JOIN,形成的中间表为两个表的笛卡尔积。
一般称为内连接,有INNER
JOIN,形成的中间表为两个表经过ON条件过滤后的笛卡尔积。
但是,这两个查询的结果是一样的。
2)左向外联:
是用的是LEFT JOIN或LEFT OUTER JOIN
连接语句。
根据两张表的关系(外键关联),笛卡尔过滤,也就是求出两张表的交集, 如果交集中,左边表的行, 在右边表中没有匹配,则该条记录左边表有数据, 右边表所有的字段都为null。
左外连接时,写where语句的独立查询条件:
规则, on后面写连接条件, where后写查询条件
3)右外连接:
RIGHT JOIN 或 RIGHT OUTER JOIN
连接语句
和左外连接是相反的,查出的两张表的交集, 如果这条记录,右边表有数据,左边表没有, 则把左边表的字段都设置为null。
案例:
内连接查询:
左连接 :
对于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、 求差操作的时候用联合查询。
并且,多个表查询的时候,这些不同的连接类型可以写到一块
例如:
参考:http://blog.csdn.net/nieson2012/article/details/45789461
内联接使用比较运算符(使用像
= 或 <> 之类的比较运算符)根据每个表共有的列的值匹配两个表中的行,根据这两张表中相同列的条件,得出其 交集。例如: 检索 students和courses表中学生标识号相同的所有行。
有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行(链接表就是数据库在做查询形成的中间表)。
隐式的内连接:
没有INNER
JOIN,形成的中间表为两个表的笛卡尔积。
SELECT O.ID,O.ORDER_NUMBER,C.ID,C.NAME FROM CUSTOMERS C,ORDERS O WHERE C.ID=O.CUSTOMER_ID;显示的内连接:
一般称为内连接,有INNER
JOIN,形成的中间表为两个表经过ON条件过滤后的笛卡尔积。
SELECT O.ID,O.ORDER_NUMBER,C.ID,C.NAME FROM CUSTOMERS C INNER JOIN ORDERS O ON C.ID=O.CUSTOMER_ID;
但是,这两个查询的结果是一样的。
2)左向外联:
是用的是LEFT JOIN或LEFT OUTER JOIN
连接语句。
根据两张表的关系(外键关联),笛卡尔过滤,也就是求出两张表的交集, 如果交集中,左边表的行, 在右边表中没有匹配,则该条记录左边表有数据, 右边表所有的字段都为null。
左外连接时,写where语句的独立查询条件:
规则, on后面写连接条件, where后写查询条件
SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME FROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID WHERE O.ORDER_NUMBER<>'MIKE_ORDER001';
3)右外连接:
RIGHT JOIN 或 RIGHT OUTER JOIN
连接语句
和左外连接是相反的,查出的两张表的交集, 如果这条记录,右边表有数据,左边表没有, 则把左边表的字段都设置为null。
案例:
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 存在关系
内连接查询:
select a.*,b.* from a inner join b on a.id=b.parent_id 结果是 1 张3 1 23 1 2 李四 2 34 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右连接 :
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
对于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、 求差操作的时候用联合查询。
并且,多个表查询的时候,这些不同的连接类型可以写到一块
例如:
SELECT T1.C1,T2.CX,T3.CY FROM TAB1 T1 INNER JOIN TAB2 T2 ON (T1.C1=T2.C2) INNER JOIN TAB3 T3 ON (T1.C1=T2.C3) LEFT OUTER JOIN TAB4 ON(T2.C2=T3.C3); WHERE T1.X >T3.Y;
参考:http://blog.csdn.net/nieson2012/article/details/45789461
相关文章推荐
- SQL查询语句精华使用简要----关于连接
- sql:常用sql语句整理二 (连接查询)
- 关于过去工作的一些总结:常用sql语句以及数据库查询优化
- 关于数据库查询语句SqlDataReader的连接释放问题的解决办法
- SQL常用查询语句
- SQL常用查询语句
- SQL语句:一种连接本表2个查询结果的复杂sql语句、一种查找一列有重复值的语句
- DBA常用sql语句-查询表空间大小语句
- 常用的几个SQL 查询语句
- oracle中常用经典sql查询语句。
- ADO带密码的数据连接、查询一个记录集、执行一SQL语句
- 三表左连接查询的sql语句写法
- 关于《一个SQL语句查询问题(查询最小值)(急)》回复里面没有正确理想的答案!
- sql语句的优化分析之一查询语句中左连接和函数效率分析比较
- sql语句实现2个表的查询(内连接)
- SQL查询语句:关于时间的比较
- 关于MSSQL通过SQL语句导表和查询
- 常用的sql语句查询例子
- 整理出的数据库中几个常用sql查询语句
- SQL常用查询语句