zoukankan      html  css  js  c++  java
  • 交叉连接(CROSS JOIN)

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

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

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

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

     
    图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,然后过滤得到的中间表

     
    图9.26  交叉连接STUDENT表和COURSE表的查询结果
     
  • 相关阅读:
    【SqlServer系列】表达式(expression)
    【SqlServer系列】语法定义符号解析
    Docker常用命令<转>
    VMware下的Centos7联网并设置固定IP
    redis的setbit命令
    Java并发编程:并发容器之CopyOnWriteArrayList<转>
    Java并发编程:volatile关键字解析<转>
    Java并发编程:阻塞队列 <转>
    Java并发编程:Lock和Synchronized <转>
    Jackson学习笔记(三)<转>
  • 原文地址:https://www.cnblogs.com/wfy680/p/11967151.html
Copyright © 2011-2022 走看看