交叉连接(CROSS JOIN)_交叉连接

交叉连接(CROSS JOIN)_交叉连接除了在FROM子句中使用逗号间隔连接的表外,SQL还支持另一种被称为交叉连接的操作,它们都返回被连接的两个表所有数据行的笛卡尔积,返回到的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。惟一的不同在于,交叉连接分开列名时,使用CROSS JOIN关键字而不是逗号。

 

除了在FROM子句中使用逗号间隔连接的表外,SQL还支持另一种被称为交叉连接的操作,它们都返回被连接的两个表所有数据行的笛卡尔积,返回到的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。惟一的不同在于,交叉连接分开列名时,使用CROSS JOIN关键字而不是逗号。

实际上,下面两个表达式是完全等价的。

 

SELECT  *  FROM  table1, table2
SELECT  *  FROM  table1  CROSS JOIN  table2

 

图9.25给出了典型的交叉连接示意图。

 

交叉连接(CROSS JOIN)_交叉连接 
图9.25  交叉连接

 

实例15  交叉连接STUDENT表和COURSE表

交叉连接STUDENT表和COURSE表,查询所有同学的学号、姓名、课程代码、课程名称、考试时间和成绩信息。实例代码:

 

SELECT       SNO,  SNAME, S.CNO, C.CNAME, CTEST, MARK
FROM      STUDENT  AS  S
CROSS JOIN COURSE   AS  C   
WHERE  S. CNO = C. CNO
AND   MARK>=60

 

运行结果如图9.26所示。

注意 在使用CROSS JOIN关键字交叉连接表时,因为生成的是两个表的笛卡尔积,因而不能使用ON关键字,只能在WHERE子句中定义搜索条件。

事实上,直接使用CROSS JOIN很少得到想要的结果,但是,正如实例所示,作为查询的第一步,DBMS通常在FROM子句中,对连接的表进行CROSS JOIN,然后过滤得到的中间表

 

交叉连接(CROSS JOIN)_交叉连接 
图9.26  交叉连接STUDENT表和COURSE表的查询结果

 

今天的文章交叉连接(CROSS JOIN)_交叉连接分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/54687.html

(0)
编程小号编程小号
上一篇 2023-08-28 23:46
下一篇 2023-08-29

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注