自然连接(NATURAL JOIN)

自然连接(NATURAL JOIN)是一种特殊的等价连接,它将表中具有相同名称的列自动进行记录匹配。自然连接不必指定任何同等连接条件。图9.9给出了典型的自然连接示意图。

  
图9.9  自然连接

自然连接自动判断相同名称的列,而后形成匹配。缺点是,虽然可以指定查询结果包括哪些列,但不能人为地指定哪些列被匹配。另外,自然连接的一个特点是连接后的结果表中匹配的列只有一个,如图9.9所示,在自然连接后的表中,只有一列C。

实例6  使用NATURAL JOIN进行查询

从STUDENT表和TEACHER表中查询学生姓名、所在系、所修的本系教师开设的课程的课程号以及开课教师姓名。这时候就可以采用NATURAL JOIN对两个表进行自然连接。实例代码:

SELECT   SNAME, DNAME, CNO, TNAME
FROM   STUDENT NATURAL JOIN TEACHER

当DBMS执行查询时,将把来自STUDENT表的行与来自TEACHER表中的行通过CNO和DNAME列进行匹配连接。即只有两个表中的CNO和DNAME列的值都相等的行,才连接起来,作为结果表中的行,而CNO和DNAME列在结果表中只出现一次,因此在查询时就不需指明TEACHER.DNAME或是STUDENT.DNAME。

注意 有些DBMS产品,如SQL Server,不支持NATURAL JOIN连接符,因此这里无法给出该实例代码的运行结果。

事实上,使用NATURAL JOIN运算符进行自然连接,与检查两个源表中同名列值相等的WHERE子句是等价的。因此,上例的实现也可表示如下。

SELECT   SNAME, S.DNAME, S.CNO, TNAME
FROM   STUDENT AS S, TEACHER AS T
WHERE  S.DNAME = T.DNAME
AND   S.CNO = T.CNO

运行结果如图9.10所示:

 
图9.10  另一种自然连接的查询结果

与自然连接不同,采用这种方式进行表的连接,虽然两表的CNO和DNAME列相等,但它们在结果表中出现了两次,因此在SELECT语句中,如果要查询这两个字段,必须指明是哪个表的字段。

事实上,使用基于WHERE子句的等值连接要比使用NATURAL JOIN运算符进行自然连接要灵活得多。正如前面介绍的,使用NATURAL JOIN运算符自动判断出具有相同名称的列,而后形成匹配,不能人为地指定哪些列被匹配。当自然连接STUDENT表和TEACHER表时,CNO和DNAME列同时被匹配,而不能只匹配一列。而使用WHERE子句则可以实现任意列的匹配。

实例7  使用WHERE子句进行等值连接查询

从STUDENT表和TEACHER表中查询学生姓名、所在系、所修的所有课程的课程号以及开课教师姓名。这时,STUDENT表和TEACHER表只需将CNO字段匹配即可。实例代码:

SELECT   SNAME, S.DNAME, S.CNO, TNAME
FROM   STUDENT AS S, TEACHER AS T
WHERE  S.CNO = T.CNO
ORDER BY  SNAME

运行结果如图9.11所示。

 
图9.11  STUDENT表和TEACHER表匹配CNO字段的查询结果

在这种情况下,就不可能使用NATURAL JOIN运算符实现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/273454.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自连接

9.3 表的连接类型 9.3.1 自连接 自连接是指表与其自身进行连接,这就需要用到前面介绍的表别名。下面通过一个具体实例来讲解自连接的应用。 实例5 自连接的使用方法 查询成绩中存在不及格课程的学生的姓名、所在系、所有的课程及成绩信息。如果采用前面介绍的…

LIKE运算符

6.5 使用LIKE进行模糊查询 当只知道部分字符串时,可使用LIKE运算符来查询数据库,找出与其相关的整个字符串。因此,当把关键字LIKE用在WHERE子句中时,可以比较两个字符串的部分匹配。当对字符串内容有些印象,但并不知…

AND运算符

6.2 组合查询条件 在前一章提到的WHERE子句进行查询时,WHERE子句后面的搜索条件只是单一的。实际上,可以通过布尔运算符AND和OR,将多个单独的搜索条件结合在一个WHERE子句中,形成一个复合的搜索条件。当对复合搜索条件求值时&a…

OR运算符

6.2.2 OR运算符 OR运算符表示“或”的关系。当可能有多个条件为True,但只要有一个为True就满足搜索要求时,可以使用OR运算符来组合搜索条件。OR在结合两个布尔表达式时,只要其中一个条件为True时,便传回True。OR运算符的真值表…

Java基础---网络编程

第一讲 概述 1、网络模型:OSI参考模型和TCP/IP参考模型 图示: 一般来说开发处于传输层和网际层,应用层为:FTP和HTTP协议等,传输层为:UDP和TCP等,网际层为:IP。 通常用户操作的是…

AND、OR运算符的组合使用

6.2.3 AND、OR运算符的组合使用 在WHERE子句中,通过AND、OR运算符可以同时连接多个条件,当然AND、OR运算符也可以同时使用。但是当AND、OR运算符同时存在时,其优先级如何确定呢?与大多数语言一样,SQL语言认为AND运算…

IN运算符的使用

6.3 IN运算符 在查询中,有时只要满足多个条件中的一个条件即可,如查询地址在北京、上海或者重庆的学生信息,这时候可以使用IN运算符。 6.3.1 IN运算符的使用 IN运算符允许根据一行记录中,是否有一列包括在一系列值之中&#…

NOT运算符与运算符

6.4.2 NOT运算符与<>运算符 对于简单的条件查询&#xff0c;NOT运算符与<>运算符的功能几乎没有什么区别&#xff0c;那么NOT运算符的优势体现在哪里呢&#xff1f;答案是它可以与其他运算符组合使用&#xff0c;这一点是<>运算符所不能实现的。在6.4.1节已…

“%”通配符

6.5.2 “%”通配符 在SQL语言中最常用的通配符可能就是“%”了&#xff0c;它表示任意字符的匹配&#xff0c;且不计字符的多少。下面通过几个典型实例来说明“%”通配符的使用。 1&#xff0e;开头&#xff0f;结尾匹配 从COURSE表中查询所有以“计算机”开头的所有课程的…

Wireshark基本介绍和学习TCP三次握手

Wireshark基本介绍和学习TCP三次握手 原文&#xff1a;http://www.cnblogs.com/TankXiao/archive/2012/10/10/2711777.html wireshark介绍 wireshark的官方下载网站&#xff1a; http://www.wireshark.org/ wireshark是非常流行的网络封包分析软件&#xff0c;功能十分强大。可…

“_”通配符

6.5.3 “_”通配符 “_”通配符的功能与“%”通配符基本相同&#xff0c;只是它只表示任意一个字符的匹配。当然&#xff0c;要表示两个字符的匹配&#xff0c;就需要使用两个“_”通配符&#xff0c;即写成“__”。 只有在用户确定所要查询的字符串的个数&#xff0c;只是不…

“[]”通配符

6.5.4 “[]”通配符 “[]”通配符用于指定一系列的字符&#xff0c;只要满足这些字符其中之一&#xff0c;且位置出现在“[]”通配符的位置的字符串就满足查询条件。 当然&#xff0c;各种通配符也可以组合使用。组合使用各种通配符时&#xff0c;一定要弄清其表示的匹配条…

QT分页控件,开源,供大家使用

下载地址&#xff1a;http://files.cnblogs.com/dragonsuc/qt5.rar 转载于:https://www.cnblogs.com/dragonsuc/p/4242342.html

STL学习小结

STL就是Standard Template Library&#xff0c;标准模板库。这可能是一个历史上最令人兴奋的工具的最无聊的术语。从根本上说&#xff0c;STL是一些“容器”的集合&#xff0c;这些“容器”有list, vector,set,map等&#xff0c;STL也是算法和其它一些组件的集合。这里的“容器…

内连接(INNER JOIN)

9.3.3 内连接&#xff08;INNER JOIN&#xff09; 内连接也称为等同连接&#xff0c;返回的结果集是两个表中所有相匹配的数据&#xff0c;而舍弃不匹配的数据。也就是说&#xff0c;在这种查询中&#xff0c;DBMS只返回来自源表中的相关的行&#xff0c;即查询的结果表包含的…

外连接(OUTER JOIN)

9.3.4 外连接&#xff08;OUTER JOIN&#xff09; 不管是内连接还是带WHERE子句的多表查询&#xff0c;都组合自多个表&#xff0c;并生成结果表。换句话说&#xff0c;如果任何一个源表中的行在另一个源表中没有匹配&#xff0c;DBMS将不把该行放在最后的结果表中。 而外连…

Android应用切换皮肤功能实现

原文地址&#xff1a;http://www.eoeandroid.com/thread-318159-1-1.html 现在大多数android应用都支持切换皮肤的功能。比如千千静听&#xff0c;墨迹天气等等。本文介绍两种切换皮肤的方法。1.第一种是通过安装皮肤apk的方式。当安装了皮肤apk包之后&#xff0c;主程序只需要…

交叉连接(CROSS JOIN)

9.3.5 交叉连接&#xff08;CROSS JOIN&#xff09; 除了在FROM子句中使用逗号间隔连接的表外&#xff0c;SQL还支持另一种被称为交叉连接的操作&#xff0c;它们都返回被连接的两个表所有数据行的笛卡尔积&#xff0c;返回到的数据行数等于第一个表中符合查询条件的数据行数…

UNION运算符

9.4.2 UNION运算符 在SQL中&#xff0c;UNION运算符用于执行集合并的运算。关于UNION运算符的使用&#xff0c;这里通过实例来说明。 实例16 使用UNION运算符执行集合并的运算 在STUDENT表中&#xff0c;查询选修了1号或者10号课程的学生的学号、姓名、所在系信息。实例代…

「OC」类的深入研究、description方法和sel

一、类的深入研究 &#xff08;一&#xff09;类的本质 类本身也是一个对象&#xff0c;是class类型的对象&#xff0c;简称“类对象”。 Class类型的定义&#xff1a; Typedef struct obj class *class; 类名就代表着类对象&#xff0c;每个类只有一个类对象。 利用class 创建…