文档详情

SQL各种连接查询详解(左连接、右连接..).docx

发布:2017-12-18约4.57千字共5页下载文档
文本预览下载声明
SQL各种连接查询详解(左连接、右连接..)一、交叉连接(cross join)交叉连接(cross join):有两种,显式的和隐式的,不带on子句,返回的是两表的乘积,也叫笛卡尔积。例如:下面的语句1和语句2的结果是相同的。语句1:隐式的交叉连接,没有cross join。select?o.id, o.order_number, c.id, c.name?from?orders o , customers c?where?o.id=1;?语句2:显式的交叉连接,使用cross join。select?o.id,o.order_number,c.id,c.name?from?orders o?cross?join?customers c?whereo.id=1;?语句1和语句2的结果是相同的,查询结果如下:?二、内连接(inner join)内连接(inner join):有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行。(所谓的链接表就是数据库在做查询形成的中间表)。例如:下面的语句3和语句4的结果是相同的。语句3:隐式的内连接,没有inner join,形成的中间表为两个表的笛卡尔积。select?o.id,o.order_number,c.id,c.name?from?customers c, orders o?wherec.id=o.customer_id;?语句4:显示的内连接,一般称为内连接,有inner join,形成的中间表为两个表经过on条件过滤后的笛卡尔积。select?o.id,o.order_number,c.id,c.name?from?customers c?inner?join?orders o?onc.id=o.customer_id;?语句3和语句4的查询结果:?三、外连接(outer join):?????外连不但返回符合连接和查询条件的数据行,还返回不符合条件的一些行。外连接分三类:左外连接(left outer join)、右外连接(right outer join)和全外连接(full outer join)。三者的共同点是都返回符合连接条件和查询条件(即:内连接)的数据行。不同点如下:左外连接还返回左表中不符合连接条件单符合查询条件的数据行。右外连接还返回右表中不符合连接条件单符合查询条件的数据行。全外连接还返回左表中不符合连接条件单符合查询条件的数据行,并且还返回右表中不符合连接条件单符合查询条件的数据行。全外连接实际是上左外连接和右外连接的数学合集(去掉重复),即“全外=左外 union 右外”。说明:左表就是在“(left outer join)”关键字左边的表。右表当然就是右边的了。在三种类型的外连接中,outer 关键字是可省略的。下面举例说明:语句5:左外连接(left outer join)select?o.id,o.order_number,o.customer_id,c.id,c.name?from?orders o?left?outer?joincustomers c?on?c.id=o.customer_id;?语句6:右外连接(right outer join)select?o.id,o.order_number,o.customer_id,c.id,c.name?from?orders o?right?outer?joincustomers c?on?c.id=o.customer_id;?注意:where条件放在on后面查询的结果是不一样的。例如:语句7:where条件独立。select?o.id,o.order_number,o.customer_id,c.id,c.name?from?orders o?left?outer?joincustomers c?on?c.id=o.customer_id?where?o.order_numbermike_order001;?语句8:将语句7中的where条件放到on后面。select?o.id,o.order_number,o.customer_id,c.id,c.name?from?orders o?left?outer?joincustomers c?on?c.id=o.customer_id?and?o.order_numbermike_order001;?从语句7和语句8查询的结果来看,显然是不相同的,语句8显示的结果是难以理解的。因此,推荐在写连接查询的时候,on后面只跟连接条件,而对中间表限制的条件都写到where子句中。语句9:全外连接(full outer join)。select?o.id,o.order_number,o.customer_id,c.id,c.name?
显示全部
相似文档