zoukankan      html  css  js  c++  java
  • MySQL之表连接-> 内连接,左外连接,右外链接,全连接

    1、首先创建student库

    create database student;

    2、 在数据库中创建boy表 和 girl表,

    mysql> create table boy(
        ->  boyId int primary key auto_increment,
        -> boyName varchar(100) not null,
        -> age int,
        -> connectId int)
        -> auto_increment = 1;
    mysql> create table girl(
        -> girlid int primary key auto_increment,
        -> girlName varchar(100) not null,
        -> age int,
        -> connectId int)
        -> auto_increment = 101;

    ① 对boy表插入部分数据

    mysql> insert into boy(boyName,age) values('李易峰',30);
    mysql> insert into boy(boyName,age) values('吴奇隆',40);
    mysql> insert into boy(boyName,age) values('周润发',55);
    mysql> insert into boy(boyName,age) values('周星驰',45);
    mysql> insert into boy(boyName,age) values('刘德华',47);
    mysql> insert into boy(boyName,age) values('成龙',60);
    mysql> select * from boy;
    +-------+---------+-----+-----------+
    | boyId | boyName | age | connectId |
    +-------+---------+-----+-----------+
    |     1 | 李易峰  |  30 | NULL      |
    |     2 | 吴奇隆  |  40 | NULL      |
    |     3 | 周润发  |  55 | NULL      |
    |     4 | 周星驰  |  45 | NULL      |
    |     5 | 刘德华  |  47 | NULL      |
    |     6 | 成龙    |  60 | NULL      |
    +-------+---------+-----+-----------+

    ② 对girl表插入部分数据

    mysql> insert into girl(girlName,age) values('刘亦菲',31);
    mysql> insert into girl(girlName,age) values('唐嫣',35);
    mysql> insert into girl(girlName,age) values('刘诗诗',38);
    mysql> insert into girl(girlName,age) values('马苏',30);
    mysql> insert into girl(girlName,age) values('杨幂',39);
    mysql> insert into girl(girlName,age) values('赵丽颖',29);
    mysql> select * from girl;
    +--------+----------+-----+-----------+
    | girlid | girlName | age | connectId |
    +--------+----------+-----+-----------+
    |    101 | 刘亦菲   |  31 | NULL      |
    |    102 | 唐嫣     |  35 | NULL      |
    |    103 | 刘诗诗   |  38 | NULL      |
    |    104 | 马苏     |  30 | NULL      |
    |    105 | 杨幂     |  39 | NULL      |
    |    106 | 赵丽颖   |  29 | NULL      |
    +--------+----------+-----+-----------+

    3、修改表中的connectId,利用boy表中的boyId 连接girl表中的girlId

     ① boyId=2 连接 girlId = 102

    mysql> update boy set connectId=102 where boyId=2;

    ② boyId=3 连接 girlId = 104

    mysql> update boy set connectId=104 where boyId=3;

    ③  boyId=6 连接 girlId = 105

    mysql> update boy set connectId=105 where boyId=6;

    得出boy表

    mysql> select * from boy;
    +-------+---------+-----+-----------+
    | boyId | boyName | age | connectId |
    +-------+---------+-----+-----------+
    |     1 | 李易峰  |  30 | NULL      |
    |     2 | 吴奇隆  |  40 |       102 |
    |     3 | 周润发  |  55 |       104 |
    |     4 | 周星驰  |  45 | NULL      |
    |     5 | 刘德华  |  47 | NULL      |
    |     6 | 成龙    |  60 |       105 |
    +-------+---------+-----+-----------+

    4、修改表中的connectId,利用girl表中的girlId 连接boy表中的boyId

    ① girlId=101 连接 boyd = 3

    mysql> update girl set connectId=3 where girlId=101;

    ② girlId=103 连接 boyd = 4

    mysql> update girl set connectId=4 where girlId=103;

    ③ girlId=105 连接 boyd = 6

    update girl set connectId=6 where girlId=105;

    得出girl表

    mysql> select * from girl;
    +--------+----------+-----+-----------+
    | girlid | girlName | age | connectId |
    +--------+----------+-----+-----------+
    |    101 | 刘亦菲   |  31 |         3 |
    |    102 | 唐嫣     |  35 | NULL      |
    |    103 | 刘诗诗   |  38 |         4 |
    |    104 | 马苏     |  30 | NULL      |
    |    105 | 杨幂     |  39 |         6 |
    |    106 | 赵丽颖   |  29 | NULL      |
    +--------+----------+-----+-----------+

    5、连接,分为 内连接、左连接、有连接, where形式连接

    ① where连接,匹配的数据显示出来

      boy表连接girl表

    mysql> select b.*,g.*
        -> from boy b,girl g
        -> where b.connectId = g.girlId;
    +-------+---------+-----+-----------+--------+----------+-----+-----------+
    | boyId | boyName | age | connectId | girlid | girlName | age | connectId |
    +-------+---------+-----+-----------+--------+----------+-----+-----------+
    |     2 | 吴奇隆  |  40 |       102 |    102 | 唐嫣     |  35 | NULL      |
    |     3 | 周润发  |  55 |       104 |    104 | 马苏     |  30 | NULL      |
    |     6 | 成龙    |  60 |       105 |    105 | 杨幂     |  39 |         6 |
    +-------+---------+-----+-----------+--------+----------+-----+-----------+
    3 rows in set

      girl表连接boy表

    mysql> select b.*,g.*
        -> from boy b,girl g
        -> where g.connectId = b.boyId;
    +-------+---------+-----+-----------+--------+----------+-----+-----------+
    | boyId | boyName | age | connectId | girlid | girlName | age | connectId |
    +-------+---------+-----+-----------+--------+----------+-----+-----------+
    |     3 | 周润发  |  55 |       104 |    101 | 刘亦菲   |  31 |         3 |
    |     4 | 周星驰  |  45 | NULL      |    103 | 刘诗诗   |  38 |         4 |
    |     6 | 成龙    |  60 |       105 |    105 | 杨幂     |  39 |         6 |
    +-------+---------+-----+-----------+--------+----------+-----+-----------+

     ② 内连接,匹配的显示出来

      boy - > girl

    mysql> select b.*,g.*
        -> from boy b inner join girl g
        -> on b.connectId = g.girlId;
    +-------+---------+-----+-----------+--------+----------+-----+-----------+
    | boyId | boyName | age | connectId | girlid | girlName | age | connectId |
    +-------+---------+-----+-----------+--------+----------+-----+-----------+
    |     2 | 吴奇隆  |  40 |       102 |    102 | 唐嫣     |  35 | NULL      |
    |     3 | 周润发  |  55 |       104 |    104 | 马苏     |  30 | NULL      |
    |     6 | 成龙    |  60 |       105 |    105 | 杨幂     |  39 |         6 |
    +-------+---------+-----+-----------+--------+----------+-----+-----------+

      girl - > boy

    mysql> select b.*,g.*
        -> from girl g inner join boy b
        -> on g.connectId = b.boyId;
    +-------+---------+-----+-----------+--------+----------+-----+-----------+
    | boyId | boyName | age | connectId | girlid | girlName | age | connectId |
    +-------+---------+-----+-----------+--------+----------+-----+-----------+
    |     3 | 周润发  |  55 |       104 |    101 | 刘亦菲   |  31 |         3 |
    |     4 | 周星驰  |  45 | NULL      |    103 | 刘诗诗   |  38 |         4 |
    |     6 | 成龙    |  60 |       105 |    105 | 杨幂     |  39 |         6 |
    +-------+---------+-----+-----------+--------+----------+-----+-----------+

     ③ 左外连接 left    join     on  ,哪个表在左边就偏向哪个表,把该表的数据全部列出来,不管匹配不匹配都显示

    mysql>  select b.*,g.*
        -> from boy b left join girl g
        -> on b.connectId = g.girlId;
    +-------+---------+-----+-----------+--------+----------+------+-----------+
    | boyId | boyName | age | connectId | girlid | girlName | age  | connectId |
    +-------+---------+-----+-----------+--------+----------+------+-----------+
    |     1 | 李易峰  |  30 | NULL      | NULL   | NULL     | NULL | NULL      |
    |     2 | 吴奇隆  |  40 |       102 |    102 | 唐嫣     |   35 | NULL      |
    |     3 | 周润发  |  55 |       104 |    104 | 马苏     |   30 | NULL      |
    |     4 | 周星驰  |  45 | NULL      | NULL   | NULL     | NULL | NULL      |
    |     5 | 刘德华  |  47 | NULL      | NULL   | NULL     | NULL | NULL      |
    |     6 | 成龙    |  60 |       105 |    105 | 杨幂     |   39 |         6 |
    +-------+---------+-----+-----------+--------+----------+------+-----------+

    ④ 右外连接 right   join     on  ,哪个表在右边就偏向哪个表,把该表的数据全部列出来,不管匹配不匹配都显示

    mysql>  select b.*,g.*
        -> from boy b right join girl g
        -> on b.connectId = g.girlId;
    +-------+---------+------+-----------+--------+----------+-----+-----------+
    | boyId | boyName | age  | connectId | girlid | girlName | age | connectId |
    +-------+---------+------+-----------+--------+----------+-----+-----------+
    |     2 | 吴奇隆  |   40 |       102 |    102 | 唐嫣     |  35 | NULL      |
    |     3 | 周润发  |   55 |       104 |    104 | 马苏     |  30 | NULL      |
    |     6 | 成龙    |   60 |       105 |    105 | 杨幂     |  39 |         6 |
    | NULL  | NULL    | NULL | NULL      |    101 | 刘亦菲   |  31 |         3 |
    | NULL  | NULL    | NULL | NULL      |    103 | 刘诗诗   |  38 |         4 |
    | NULL  | NULL    | NULL | NULL      |    106 | 赵丽颖   |  29 | NULL      |
    +-------+---------+------+-----------+--------+----------+-----+-----------+

     ⑤  全连接(笛卡尔积),MySQL不支持 full join,但是可以通过  union来实现连接结果集(剔除重复数据),会显示两张表的各自匹配的数据,union all 不会剔除重复数据

    mysql> select b.*,g.*
        -> from boy b left join girl g
        -> on b.connectId = g.girlId
        -> union
        -> select b.*,g.*
        -> from boy b right join girl g
        -> on b.connectId = g.girlId;
    +-------+---------+------+-----------+--------+----------+------+-----------+
    | boyId | boyName | age  | connectId | girlid | girlName | age  | connectId |
    +-------+---------+------+-----------+--------+----------+------+-----------+
    |     1 | 李易峰  |   30 | NULL      | NULL   | NULL     | NULL | NULL      |
    |     2 | 吴奇隆  |   40 |       102 |    102 | 唐嫣     |   35 | NULL      |
    |     3 | 周润发  |   55 |       104 |    104 | 马苏     |   30 | NULL      |
    |     4 | 周星驰  |   45 | NULL      | NULL   | NULL     | NULL | NULL      |
    |     5 | 刘德华  |   47 | NULL      | NULL   | NULL     | NULL | NULL      |
    |     6 | 成龙    |   60 |       105 |    105 | 杨幂     |   39 |         6 |
    | NULL  | NULL    | NULL | NULL      |    101 | 刘亦菲   |   31 |         3 |
    | NULL  | NULL    | NULL | NULL      |    103 | 刘诗诗   |   38 |         4 |
    | NULL  | NULL    | NULL | NULL      |    106 | 赵丽颖   |   29 | NULL      |
    +-------+---------+------+-----------+--------+----------+------+-----------+

     2018年1月16日02:12:02,睡觉...

  • 相关阅读:
    php的序列化和反序列化有什么好处?
    解析PHP多种序列化与反序列化的方法
    PHP 数组和字符串互相转换实现方法
    PHP中foreach()用法汇总
    php实现伪静态的方法
    PHP中如何定义类及其成员属性与操作
    单例模式优缺点
    PHP 单例模式解析和实战
    主从复制之莫名少表
    诡异的 ERROR 1045 (28000): Access denied for user 错误
  • 原文地址:https://www.cnblogs.com/liangwh520/p/8292314.html
Copyright © 2011-2022 走看看