争怎路由网/应用软件/内容

MySQL Join详细说明

应用软件2024-05-08 阅读
数据库,简而言之可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据进行新增、截取、更新、删除等操作。所谓“数据库”是以一定方式储存在一起、能与多个用户共享、具有尽可能小的冗余度、与应用程序彼此独立的数据集合。
还是先 Create table 吧

  create table emp(
  id int not null primary key,
  name varchar(10)
  );

  create table emp_dept(
  dept_id varchar(4) not null,
  emp_id int not null,
  emp_name varchar(10),
  primary key (dept_id,emp_id));

  insert into emp() values
  (1,"Dennis-1"),
  (2,"Dennis-2"),
  (3,"Dennis-3"),
  (4,"Dennis-4"),
  (5,"Dennis-5"),
  (6,"Dennis-6"),
  (7,"Dennis-7"),
  (8,"Dennis-8"),
  (9,"Dennis-9"),
  (10,"Dennis-10");

  insert into emp_dept() values
  ("R&D",1,"Dennis-1"),
  ("DEv",2,"Dennis-2"),
  ("R&D",3,"Dennis-3"),
  ("Test",4,"Dennis-4"),
  ("Test",5,"Dennis-5");

[page_break]

 >> left join
  -------------
  select a.id,a.name,b.dept_id
  from emp a left join emp_dept b on (a.id=b.emp_id);

  # 挑出左边的 table emp 中的所有资料,即使 emp_dept 中没有的资料也挑出来,没有的就用 NULL   来显示,
  # 也即显示资料是以左边的 table emp 中的资料为基础

  mysql> select a.id,a.name,b.dept_id
  -> from emp a left join emp_dept b on (a.id=b.emp_id);
  +----+-----------+---------+
  (专业提供视频软件下载)

id (专业提供视频软件下载)

name      (专业提供视频软件下载)

dept_id (专业提供视频软件下载)


  +----+-----------+---------+
  (专业提供视频软件下载)

  1 (专业提供视频软件下载)

Dennis-1  (专业提供视频软件下载)

R&D     (专业提供视频软件下载)


  (专业提供视频软件下载)

  2 (专业提供视频软件下载)

Dennis-2  (专业提供视频软件下载)

DEv     (专业提供视频软件下载)


  (专业提供视频软件下载)

  3 (专业提供视频软件下载)

Dennis-3  (专业提供视频软件下载)

R&D     (专业提供视频软件下载)


  (专业提供视频软件下载)

  4 (专业提供视频软件下载)

Dennis-4  (专业提供视频软件下载)

Test    (专业提供视频软件下载)


  (专业提供视频软件下载)

  5 (专业提供视频软件下载)

Dennis-5  (专业提供视频软件下载)

Test    (专业提供视频软件下载)


  (专业提供视频软件下载)

  6 (专业提供视频软件下载)

Dennis-6  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

  7 (专业提供视频软件下载)

Dennis-7  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

  8 (专业提供视频软件下载)

Dennis-8  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

  9 (专业提供视频软件下载)

Dennis-9  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

10 (专业提供视频软件下载)

Dennis-10 (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  +----+-----------+---------+

  # 挑出 table emp 中有而 table emp_dept 中没有的人员资料
  select a.id,a.name,b.dept_id
  from emp a left join emp_dept b on (a.id=b.emp_id)
  where b.dept_id IS NULL;

  mysql> select a.id,a.name,b.dept_id
  -> from emp a left join emp_dept b on (a.id=b.emp_id)
  -> where b.dept_id IS NULL;

+----+-----------+---------+
  (专业提供视频软件下载)

id (专业提供视频软件下载)

name      (专业提供视频软件下载)

dept_id (专业提供视频软件下载)


  +----+-----------+---------+
  (专业提供视频软件下载)

  6 (专业提供视频软件下载)

Dennis-6  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

  7 (专业提供视频软件下载)

Dennis-7  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

  8 (专业提供视频软件下载)

Dennis-8  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

  9 (专业提供视频软件下载)

Dennis-9  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

10 (专业提供视频软件下载)

Dennis-10 (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  +----+-----------+---------+

  # 把 table emp_dept 放在左边的情形(当然以 emp_dept 中的数据为基础来显示资料,emp 中比emp_dept 中多的资料也就不会显示出来了):

  select a.id,a.name,b.dept_id
  from emp_dept b left join emp a on (a.id=b.emp_id);
  mysql> select a.id,a.name,b.dept_id
  -> from emp_dept b left join emp a on (a.id=b.emp_id);
  +------+----------+---------+
  (专业提供视频软件下载)

id   (专业提供视频软件下载)

name     (专业提供视频软件下载)

dept_id (专业提供视频软件下载)


  +------+----------+---------+
  (专业提供视频软件下载)

    2 (专业提供视频软件下载)

Dennis-2 (专业提供视频软件下载)

DEv     (专业提供视频软件下载)


  (专业提供视频软件下载)

    1 (专业提供视频软件下载)

Dennis-1 (专业提供视频软件下载)

R&D     (专业提供视频软件下载)


  (专业提供视频软件下载)

    3 (专业提供视频软件下载)

Dennis-3 (专业提供视频软件下载)

R&D     (专业提供视频软件下载)


  (专业提供视频软件下载)

    4 (专业提供视频软件下载)

Dennis-4 (专业提供视频软件下载)

Test    (专业提供视频软件下载)


  (专业提供视频软件下载)

    5 (专业提供视频软件下载)

Dennis-5 (专业提供视频软件下载)

Test    (专业提供视频软件下载)


  +------+----------+---------+


  >> right join
  ---------------
  select a.id,a.name,b.dept_id
  from emp a right join emp_dept b on (a.id=b.emp_id);
  # 挑资料时以右边 table emp_dept 中的资料为基础来显示资料

  mysql> select a.id,a.name,b.dept_id
  -> from emp a right join emp_dept b on (a.id=b.emp_id);


[page_break]

+------+----------+---------+
  (专业提供视频软件下载)

id   (专业提供视频软件下载)

name     (专业提供视频软件下载)

dept_id (专业提供视频软件下载)


  +------+----------+---------+
  (专业提供视频软件下载)

    2 (专业提供视频软件下载)

Dennis-2 (专业提供视频软件下载)

DEv     (专业提供视频软件下载)


  (专业提供视频软件下载)

    1 (专业提供视频软件下载)

Dennis-1 (专业提供视频软件下载)

R&D     (专业提供视频软件下载)


  (专业提供视频软件下载)

    3 (专业提供视频软件下载)

Dennis-3 (专业提供视频软件下载)

R&D     (专业提供视频软件下载)


  (专业提供视频软件下载)

    4 (专业提供视频软件下载)

Dennis-4 (专业提供视频软件下载)

Test    (专业提供视频软件下载)


  (专业提供视频软件下载)

    5 (专业提供视频软件下载)

Dennis-5 (专业提供视频软件下载)

Test    (专业提供视频软件下载)


  +------+----------+---------+
  5 rows in set (0.00 sec)

  # 我们再把 table 的位置交换一下,再用 right join 试试

  select a.id,a.name,b.dept_id
  from emp_dept b right join emp a on (a.id=b.emp_id);

  mysql> select a.id,a.name,b.dept_id
  -> from emp_dept b right join emp a on (a.id=b.emp_id);
  +----+-----------+---------+
  (专业提供视频软件下载)

id (专业提供视频软件下载)

name      (专业提供视频软件下载)

dept_id (专业提供视频软件下载)


  +----+-----------+---------+
  (专业提供视频软件下载)

  1 (专业提供视频软件下载)

Dennis-1  (专业提供视频软件下载)

R&D     (专业提供视频软件下载)


  (专业提供视频软件下载)

  2 (专业提供视频软件下载)

Dennis-2  (专业提供视频软件下载)

DEv     (专业提供视频软件下载)


  (专业提供视频软件下载)

  3 (专业提供视频软件下载)

Dennis-3  (专业提供视频软件下载)

R&D     (专业提供视频软件下载)


  (专业提供视频软件下载)

  4 (专业提供视频软件下载)

Dennis-4  (专业提供视频软件下载)

Test    (专业提供视频软件下载)


  (专业提供视频软件下载)

  5 (专业提供视频软件下载)

Dennis-5  (专业提供视频软件下载)

Test    (专业提供视频软件下载)


  (专业提供视频软件下载)

  6 (专业提供视频软件下载)

Dennis-6  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

  7 (专业提供视频软件下载)

Dennis-7  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

  8 (专业提供视频软件下载)

Dennis-8  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

  9 (专业提供视频软件下载)

Dennis-9  (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  (专业提供视频软件下载)

10 (专业提供视频软件下载)

Dennis-10 (专业提供视频软件下载)

NULL    (专业提供视频软件下载)


  +----+-----------+---------+

# 是不是和 left join 一样了?

  >> direct join
  --------------
  # 如果用right join 同不用 Join 直接挑资料是相同的,它等介於以下的指令

  select a.id,a.name,b.dept_id
  from emp a ,emp_dept b 
  where a.id=b.emp_id;

  mysql> select a.id,a.name,b.dept_id
  -> from emp a ,emp_dept b
  -> where a.id=b.emp_id;
  +----+----------+---------+
  (专业提供视频软件下载)

id (专业提供视频软件下载)

name     (专业提供视频软件下载)

dept_id (专业提供视频软件下载)


  +----+----------+---------+
  (专业提供视频软件下载)

  2 (专业提供视频软件下载)

Dennis-2 (专业提供视频软件下载)

DEv     (专业提供视频软件下载)


  (专业提供视频软件下载)

  1 (专业提供视频软件下载)

Dennis-1 (专业提供视频软件下载)

R&D     (专业提供视频软件下载)


  (专业提供视频软件下载)

  3 (专业提供视频软件下载)

Dennis-3 (专业提供视频软件下载)

R&D     (专业提供视频软件下载)


  (专业提供视频软件下载)

  4 (专业提供视频软件下载)

Dennis-4 (专业提供视频软件下载)

Test    (专业提供视频软件下载)


  (专业提供视频软件下载)

  5 (专业提供视频软件下载)

Dennis-5 (专业提供视频软件下载)

Test    (专业提供视频软件下载)


  +----+----------+---------+


  怎样,弄明白了吗?

  Enjoy it!



全新的路由器不仅让你更稳定快速地连接无线网络,更可以让家中的智能设备连接在一起。



……

相关阅读