沧州制作网站,个人网站开发计划书,网站建设会销,网站列表页模板自然连接#xff08;NATURAL JOIN#xff09;是一种特殊的等价连接#xff0c;它将表中具有相同名称的列自动进行记录匹配。自然连接不必指定任何同等连接条件。图9.9给出了典型的自然连接示意图。 图9.9 自然连接 自然连接自动判断相同名称的列#xff0c;而后形成匹配。… 自然连接NATURAL JOIN是一种特殊的等价连接它将表中具有相同名称的列自动进行记录匹配。自然连接不必指定任何同等连接条件。图9.9给出了典型的自然连接示意图。 图9.9 自然连接 自然连接自动判断相同名称的列而后形成匹配。缺点是虽然可以指定查询结果包括哪些列但不能人为地指定哪些列被匹配。另外自然连接的一个特点是连接后的结果表中匹配的列只有一个如图9.9所示在自然连接后的表中只有一列C。 实例6 使用NATURAL JOIN进行查询 从STUDENT表和TEACHER表中查询学生姓名、所在系、所修的本系教师开设的课程的课程号以及开课教师姓名。这时候就可以采用NATURAL JOIN对两个表进行自然连接。实例代码 SELECT SNAME, DNAME, CNO, TNAMEFROM 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, TNAMEFROM STUDENT AS S, TEACHER AS TWHERE S.DNAME T.DNAMEAND 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, TNAMEFROM STUDENT AS S, TEACHER AS TWHERE S.CNO T.CNOORDER BY SNAME 运行结果如图9.11所示。 图9.11 STUDENT表和TEACHER表匹配CNO字段的查询结果 在这种情况下就不可能使用NATURAL JOIN运算符实现。