一.介绍
首先说一下,我们写项目一般都会建一个数据库,那数据库里面是不是存了好多张表啊,不可能把所有的数据都放到一张表里面,肯定要分表来存数据,这样节省空间,数据的组织结构更清晰,解耦和程度更高,但是这些表本质上是不是还是一个整体啊,是一个项目所有的数据,那既然分表存了,就要涉及到多个表连接查询了,比如说员工信息一张表,部门信息一张表,那如果我想让你帮我查一下技术部门有哪些员工的姓名,你怎么办,单独找员工表能实现吗,不能,单独找部门表也无法实现,因为部门表里面没有员工的信息,对不对,所以就涉及到部门表和员工表来关联到一起进行查询了,好,那我们来建立这么两张表:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
#建表 #部门表 create table department( id int , name varchar( 20 ) ); #员工表,之前我们学过foreign key,强行加上约束关联,但是我下面这个表并没有直接加foreign key,这两个表我只是让它们在逻辑意义上有关系,并没有加foreign key来强制两表建立关系,为什么要这样搞,是有些效果要给大家演示一下 #所以,这两个表是不是先建立哪个表都行啊,如果有foreign key的话,是不是就需要注意表建立的顺序了。那我们来建表。 create table employee( id int primary key auto_increment, name varchar( 20 ), sex enum( 'male' , 'female' ) not null default 'male' , age int , dep_id int ); #给两个表插入一些数据 insert into department values ( 200 , '技术' ), ( 201 , '人力资源' ), ( 202 , '销售' ), ( 203 , '运营' ); #注意这一条数据,在下面的员工表里面没有对应这个部门的数据 insert into employee(name,sex,age,dep_id) values ( 'egon' , 'male' , 18 , 200 ), ( 'alex' , 'female' , 48 , 201 ), ( 'wupeiqi' , 'male' , 38 , 201 ), ( 'yuanhao' , 'female' , 28 , 202 ), ( 'liwenzhou' , 'male' , 18 , 200 ), ( 'jingliyang' , 'female' , 18 , 204 ) #注意这条数据的dep_id字段的值,这个204,在上面的部门表里面也没有对应的部门id。所以两者都含有一条双方没有涉及到的数据,这都是为了演示一下效果设计的昂 ; #查看表结构和数据 mysql> desc department; + - - - - - - - + - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - + | field | type | null | key | default | extra | + - - - - - - - + - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - + | id | int ( 11 ) | yes | | null | | | name | varchar( 20 ) | yes | | null | | + - - - - - - - + - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - + mysql> desc employee; + - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - - - - - - - - - - + | field | type | null | key | default | extra | + - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - - - - - - - - - - + | id | int ( 11 ) | no | pri | null | auto_increment | | name | varchar( 20 ) | yes | | null | | | sex | enum( 'male' , 'female' ) | no | | male | | | age | int ( 11 ) | yes | | null | | | dep_id | int ( 11 ) | yes | | null | | + - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - - - - - - - - - - + mysql> select * from department; + - - - - - - + - - - - - - - - - - - - - - + | id | name | + - - - - - - + - - - - - - - - - - - - - - + | 200 | 技术 | | 201 | 人力资源 | | 202 | 销售 | | 203 | 运营 | + - - - - - - + - - - - - - - - - - - - - - + mysql> select * from employee; + - - - - + - - - - - - - - - - - - + - - - - - - - - + - - - - - - + - - - - - - - - + | id | name | sex | age | dep_id | + - - - - + - - - - - - - - - - - - + - - - - - - - - + - - - - - - + - - - - - - - - + | 1 | egon | male | 18 | 200 | | 2 | alex | female | 48 | 201 | | 3 | wupeiqi | male | 38 | 201 | | 4 | yuanhao | female | 28 | 202 | | 5 | liwenzhou | male | 18 | 200 | | 6 | jingliyang | female | 18 | 204 | + - - - - + - - - - - - - - - - - - + - - - - - - - - + - - - - - - + - - - - - - - - + |
二.多表连接查询
1
2
3
4
5
|
#重点:外链接语法 select 字段列表 from 表 1 inner|left|right join 表 2 on 表 1. 字段 = 表 2. 字段; |
1、交叉连接:不适用任何匹配条件。生成笛卡尔积
补充一点:select 查询表的时候,后面可以跟多张表一起查询:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
mysql> select * from department,employee; #表用逗号分隔,看我查询时表的顺序,先department后employee,所以你看结果表的这些字段,是不是就是我们两个表字段并且哪个表在前面,哪个表的字段就在前面 + - - - - - - + - - - - - - - - - - - - - - + - - - - + - - - - - - - - - - - - + - - - - - - - - + - - - - - - + - - - - - - - - + | id | name | id | name | sex | age | dep_id | + - - - - - - + - - - - - - - - - - - - - - + - - - - + - - - - - - - - - - - - + - - - - - - - - + - - - - - - + - - - - - - - - + | 200 | 技术 | 1 | egon | male | 18 | 200 | | 201 | 人力资源 | 1 | egon | male | 18 | 200 | | 202 | 销售 | 1 | egon | male | 18 | 200 | | 203 | 运营 | 1 | egon | male | 18 | 200 | | 200 | 技术 | 2 | alex | female | 48 | 201 | | 201 | 人力资源 | 2 | alex | female | 48 | 201 | | 202 | 销售 | 2 | alex | female | 48 | 201 | | 203 | 运营 | 2 | alex | female | 48 | 201 | | 200 | 技术 | 3 | wupeiqi | male | 38 | 201 | | 201 | 人力资源 | 3 | wupeiqi | male | 38 | 201 | | 202 | 销售 | 3 | wupeiqi | male | 38 | 201 | | 203 | 运营 | 3 | wupeiqi | male | 38 | 201 | | 200 | 技术 | 4 | yuanhao | female | 28 | 202 | | 201 | 人力资源 | 4 | yuanhao | female | 28 | 202 | | 202 | 销售 | 4 | yuanhao | female | 28 | 202 | | 203 | 运营 | 4 | yuanhao | female | 28 | 202 | | 200 | 技术 | 5 | liwenzhou | male | 18 | 200 | | 201 | 人力资源 | 5 | liwenzhou | male | 18 | 200 | | 202 | 销售 | 5 | liwenzhou | male | 18 | 200 | | 203 | 运营 | 5 | liwenzhou | male | 18 | 200 | | 200 | 技术 | 6 | jingliyang | female | 18 | 204 | | 201 | 人力资源 | 6 | jingliyang | female | 18 | 204 | | 202 | 销售 | 6 | jingliyang | female | 18 | 204 | | 203 | 运营 | 6 | jingliyang | female | 18 | 204 | + - - - - - - + - - - - - - - - - - - - -
相关文章:
推荐阅读
本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。 ctvol管理联系方式QQ:251552304
本文章地址:https://www.ctvol.com/dtteaching/834999.html 赞 (0)
问道英文免费精选名字大全男分享
上一篇
2021年9月25日 上午2:11
闪耀暖暖好听的游戏情侣免费精选名字大全分享
下一篇
2021年9月25日 上午2:15
|