- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
SQL各种连接查询详解(左连接、右连接..)
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?
文档评论(0)