SQL 联接--->完整外联接 (完整外部联接 ..full outer join..on)
来源:互联网 发布:手机点击类软件 编辑:程序博客网 时间:2024/05/17 03:30
有表 titles(书信息表) 如下图
有表 publishers(出版社) 如下图
执行完整外联接代码:
select titles.titles_id,titles.title,publishers.pub_name from titles full outer join publishers on titles.pub_id=publishers.pub_id 结果如下图:
大家看明白了吗? 现在要讲关于完整外联接的 理论了 要顶住呀!不带睡觉啊! 不听话按行规 剁两脚指头!
一、联接( 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 表之间的完整外部联接显示所有书名和所有出版商,甚至包括那些在另一个表中没有匹配值的书名和出版商。
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 pubs
SELECT au_fname, au_lname, pub_name FROM authors CROSS JOIN publishers ORDER BY au_lname DESC
说明:结果集包含 184 行(authors 有 23 行,publishers 有 8 行;23 乘以 8 等于 184)。 不过,如果添加一个 WHERE 子句,则交叉联接的作用将同内联接一样。
- SQL 联接--->完整外联接 (完整外部联接 ..full outer join..on)
- SQL 联接--->左向外联接 (左外联接 ..left outer join..on)
- SQL 联接--->右向外联接 (右外联接 ..right outer join..on)
- SQL中表的联接(内联接,左联接,右联接,外联接,交叉联接)
- 内联接外联接全联接join的用法
- 探讨使用外联接(OUTER JOIN)联接两表时容易忽略的一个小问题
- SQL 联接--->内联接 (自然连接 join..on)
- SQL常用四种联接-内联接、左外联接、右外联接和全联接的使用
- 内联接外联接 左联接右联接 举例说明
- join联接查询--SQL中 inner join、 left join 、right join、 outer join之间的区别
- SQL Join 联接
- Oracle PL/SQL之内联接、外联接、交叉连接
- Oracle PL/SQL之内联接、外联接、交叉连接
- Oracle PL/SQL之内联接、外联接、交叉连接
- SQL 联接--->交叉联接 (交叉联接 ..cross join..)
- SQL FULL OUTER JOIN
- 完整SQL分页存储过程(支持多表联接)
- 完整SQL分页存储过程(支持多表联接)
- 用VS2005也能制作体积很小的Win32程序(2KB - 3KB)
- 计算两个日期间相隔了多少周
- 2个SQL语句的区别
- 截取系统 API 调用
- 输入一个不多于五位的正整数,判断它是几位数,分别打印出各位数字,并按逆序打印各位数字
- SQL 联接--->完整外联接 (完整外部联接 ..full outer join..on)
- Windows Sockets API实现网络异步通讯
- 多线程:声明为“静态”的成员函数如何访问类成员变量
- Swing实现Windows任务窗
- 透过色彩搜索 Flickr 图片
- 博客怎么写?
- 复习回溯算法
- PB9.0以上小写转大写
- dd