交叉连接(CROSS JOIN)
2024-09-05 01:31:10
除了在FROM子句中使用逗号间隔连接的表外,SQL还支持另一种被称为交叉连接的操作,它们都返回被连接的两个表所有数据行的笛卡尔积,返回到的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。惟一的不同在于,交叉连接分开列名时,使用CROSS JOIN关键字而不是逗号。
实际上,下面两个表达式是完全等价的。
SELECT * FROM table1, table2 |
图9.25给出了典型的交叉连接示意图。
图9.25 交叉连接 |
实例15 交叉连接STUDENT表和COURSE表
交叉连接STUDENT表和COURSE表,查询所有同学的学号、姓名、课程代码、课程名称、考试时间和成绩信息。实例代码:
SELECT SNO, SNAME, S.CNO, C.CNAME, CTEST, MARK |
运行结果如图9.26所示。
注意 在使用CROSS JOIN关键字交叉连接表时,因为生成的是两个表的笛卡尔积,因而不能使用ON关键字,只能在WHERE子句中定义搜索条件。
事实上,直接使用CROSS JOIN很少得到想要的结果,但是,正如实例所示,作为查询的第一步,DBMS通常在FROM子句中,对连接的表进行CROSS JOIN,然后过滤得到的中间表。
图9.26 交叉连接STUDENT表和COURSE表的查询结果 |
最新文章
- CSS3之新UI方案
- Intent(三)向下一个活动传递数据
- Python语法一
- Sharepoint学习笔记—习题系列--70-576习题解析 -(Q21-Q24)
- redis数据类型
- Android Touch事件传递机制解析
- HTTP协议概述
- Part 30 to 31 Talking about Interfaces in c#
- Unity5UGUI 官方教程学习笔记(三)UI BUTTON
- 【转】window.scroll 浏览器滚动条的参数总结
- jenkins构建自由风格项目[四]
- ModelBiner不验证某个属性
- JavaScript 进制转换
- Springboot -- 由于jar版本不匹配遇到的问题
- 学号:20165239 预备作业3 Linux安装及学习
- eosio.cdt:EOS智能合约工具集
- 字体选择框QFontComboBox
- Facebook ads_Business Manager
- 使用Tortoise结合Git比较两个版本的差异
- 016-sed