- 1、本文档共3页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SQL内联,左联,右联,交叉联
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?? [OUTER]JOIN 表2 ON 表1.列1=表2.列2
右外连接的语法为: SELECT select_list FROM? 表1 RIGHT[OUTER]JOIN 表2 ON 表1.列1=表2.列2
全外连接(完整外部联接)的语法为: SELECT select_list FROM? 表1 FULL[OUTER]? 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 表之间的完整外部联
您可能关注的文档
最近下载
- 《22G101三维彩色立体图集》.pdf VIP
- 二次函数应用利润问题.pptx VIP
- 3.3我是中国公民 课件六年级道德与法治上册(部编版).ppt
- 心理学-自体的分析.docx
- 幼儿园游戏活动优秀案例遴选标准.docx
- 幼儿园大班语言《神奇的象形字》 课件.pptx VIP
- 解决问题我最有办法PPT课件(精选版)19页.pptx VIP
- 现代控制工程(第五版)卢伯英习题答案解析.pdf
- [新疆]2023年中国工商银行新疆分行春季校园招聘考试参考题库含答案详解.docx
- Unit 2 We're Family! Section A 2a-2e Period 2 教学设计 人教英语七年级上册(2024).doc
文档评论(0)