zoukankan      html  css  js  c++  java
  • Mysql常用sql语句(15)- cross join 交叉连接

    测试必备的Mysql常用sql语句

    https://www.cnblogs.com/poloyy/category/1683347.html

    前言

    • 交叉连接就是求多表之间的笛卡尔积
    • 讲道理..这个我都不怎么常用..因为能用到的地方太少了;但还是要介绍的啦

    啥是笛卡尔积

    这属于数学的内容,不介绍概念,直接看栗子来知道吧!

    假设,有两个集合A、B

    A = {1,2}
    B = {3,4}

    集合A和集合B的笛卡尔积 = 集合A * 集合B;即,两表相乘,如下:

    AxB = {(1,3),(1,4),(2,3),(2,4)}
    • 在Mysql中,表与表之间的笛卡尔积不建议使用,会产生大量不合理的数据;
    • 假设两张表各有100条记录,那么表与表的笛卡尔积的数据量就有100*100=10000条了...

    cross join 的语法格式

    SELECT <字段名> FROM <表1> CROSS JOIN <表2> [WHERE]
    SELECT <字段名> FROM <表1>, <表2> [WHERE子句] 

    先看看dept、emp表有什么数据

    dept表

    emp表

    cross join单独使用的栗子

    select * from emp cross join dept;

    总记录数 = emp记录数(9) * dept记录数(4) = 36

    cross join + where 的栗子

    select * from emp as a cross join dept as b on a.dept_id = b.id;

  • 相关阅读:
    Ethical Hacking
    Ethical Hacking
    Python Ethical Hacking
    Python Ethical Hacking
    Python Ethical Hacking
    食物链 POJ
    Wireless Network POJ
    Candies POJ
    畅通工程再续 HDU
    Jungle Roads HDU
  • 原文地址:https://www.cnblogs.com/poloyy/p/12881918.html
Copyright © 2011-2022 走看看