SQL内联,左联,右联,交叉联.doc_第1页
SQL内联,左联,右联,交叉联.doc_第2页
SQL内联,左联,右联,交叉联.doc_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

SQL交叉联接 示例2008-08-27 14:09:30|分类: SQL |标签: |字号大中小订阅 有表 titles1(书信息表) 如下图有表 publishers1(出版社) 如下图执行交叉联接代码:select titles_id,title,pub_name from titles1 cross join publishers1 order by titles_id 结果如下图:大家看明白了吗?5(行数)*3(行数)=15(行数)什么叫笛卡尔积这就叫笛卡尔积 现在要讲关于交叉联接的 理论了 要顶住呀!不带睡觉啊! 不听话 按行规剁叁脚指头!一、联接( join)通过联接,可以根据各个表之间的逻辑关系从两个或多个表中检索数据。联接表示应如何使用一个表中的数据来选择另一个表中的行。联接条件通过以下方法定义两个表在查询中的关联方式: 指定每个表中要用于联接的列。典型的联接条件在一个表中指定外键,在另一个表中指定与其关联的键。指定比较各列的值时要使用的逻辑运算符(=、 等)。二、联接类型当联接表时,创建的联接类型影响出现在结果集内的行。联接类型:三、内联接内连接也叫自然连接,它是组合两个表的常用方法。自然连接将两个表中的列进行比较,将两个表中满足连接条件的行组合起来,作为结果。自然连接有两种形式的语法。语法一: SELECT 列 FROM 表1 insert JION 表2 ON 表1.列=表2.列语法二: SELECT 列 FROM 表1,表2 WHERE表1.列=表2.列【例】从titles、authors和titleauthor表中查询书的书号、书名、作者号和作者名。select titles.title_id, title, authors.au_id, au_lname from titles join titleauthor on titles.title_id=titleauthor.title_id join authors on authors.au_id=titleauthor.au_id四、外连接(Outer join)在自然连接中,只有在两个表中匹配的行才能在结果集中出现。而在外连接中可以只限制一个表,而对另外一个表不加限制(即所有的行都出现在结果集中)。外连接分为左外连接、右外连接和全外连接。左外连接是对连接条件中左边的表不加限制;右外连接是对右边的表不加限制;全外连接对两个表都不加限制,所有两个表中的行都会包括在结果集中。五、外连接(Outer join)语法左外连接的语法为: SELECT 列 FROM 表1 LEFT OUTERJOIN 表2 ON 表1.列1=表2.列2 右外连接的语法为: SELECT select_list FROM 表1 RIGHTOUTERJOIN 表2 ON 表1.列1=表2.列2 全外连接(完整外部联接)的语法为: SELECT select_list FROM 表1 FULLOUTER JOIN 表2 ON 表1.列1=表2.列2六、左向外联接 包括第一个命名表(“左”表,出现在 JOIN 子句的最左边)中的所有行。不包括右表中的不匹配行。【例35】下面的 SQL 语句说明 titles 表和 publishers 表之间的左向外联接包括所有的书名,甚至包括那些没有出版商信息的书名: Use pubs SELECT titles.title_id, titles.title, publishers.pub_name FROM titles LEFT OUTER JOIN publishers ON titles.pub_id = publishers.pub_id七、右向外联接 包括第二个命名表(“右”表,出现在 JOIN 子句的最右边)中的所有行。不包括左表中的不匹配行。【例36】在 titles 和 publishers 表之间的右向外联接将包括所有的出版商,甚至包括那些在 titles 表中没有书名的出版商。 SELECT titles.title_id, titles.title, publishers.pub_name FROM titles RIGHT OUTER JOIN publishers ON titles.pub_id = publishers.pub_id八、完整外部联接 包括所有联接表中的所有行,不论它们是否匹配。【例37】 titles 表和 publishers 表之间的完整外部联接显示所有书名和所有出版商,甚至包括那些在另一个表中没有匹配值的书名和出版商。 SELECT titles.title_id, titles.title, publishers.pub_name FROM titles FULL OUTER JOIN publishers ON titles.pub_id = publishers.pub_id九、交叉联接 没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。 【例39】 阅读以下程序: USE pubsSELECT au_fname, au_lname, pub_name FROM authors CROSS JOIN publishers ORDER

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论