数据库教程:mysql之多表查询

一.介绍 首先说一下,我们写项目一般都会建一个数据库,那数据库里面是不是存了好多张表啊,不可能把所有的数据都放到一张表里面,肯定要分表来存数据,这样节省空间,数据的组织结构更清晰,解耦和程度更高,但是这些表本质上是不是还是一个整体啊,是一个项目所有的数据,那既然分表存了,就要涉及到多个表连接查询了, …

一.介绍

  首先说一下,我们写项目一般都会建一个数据库,那数据库里面是不是存了好多张表啊,不可能把所有的数据都放到一张表里面,肯定要分表来存数据,这样节省空间,数据的组织结构更清晰,解耦和程度更高,但是这些表本质上是不是还是一个整体啊,是一个项目所有的数据,那既然分表存了,就要涉及到多个表连接查询了,比如说员工信息一张表,部门信息一张表,那如果我想让你帮我查一下技术部门有哪些员工的姓名,你怎么办,单独找员工表能实现吗,不能,单独找部门表也无法实现,因为部门表里面没有员工的信息,对不对,所以就涉及到部门表和员工表来关联到一起进行查询了,好,那我们来建立这么两张表:

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 |
+------+-------------

相关文章:

  • 阿里云ESC 安装 MYSQL8.0的教程

    打开 连接工具,我用的是mobaxterm_personal_12.1 (官网下载地址:) 连接到 ecs,然后移除 默认的 mariadb ... [阅读全文]

  • 【转】mysql保存图片技术决定:保存二进制文件还是只保存图片相对路径,图片放在硬盘上面?

    最近遇到上面这个问题,一开始我就果断否决了数据库保存图片的策略,主要是太蠢!事实上我的决定是正确的,我仅仅理解为mysql读写性能提高的境界,具体为... [阅读全文]

  • Mysql中校对集utf8_unicode_ci与utf8_general_ci的区别说明

    下面摘录一下mysql 5.1中文手册中关于utf8_unicode_ci与utf8_general_ci的说明: 当前,utf8_... [阅读全文]

  • mysql初始化/usr/local/mysql/bin/mysqld: error while loading shared libraries: libnuma.so.1: cannot open shared object file: No such file or directory

    [root@test153 ~]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --... [阅读全文]

  • Ubuntu手动安装mysql5.7.10

    本教程为大家分享了ubuntu手动安装mysql5.7.10的过程,供大家参考,具体内容如下 1、下载安装包 mysql官网... [阅读全文]

  • MySQL中开启和使用通用查询日志的实例教程

    开启通用查询日志 因为为了性能考虑,一般通用查询日志general log不会开启。slow log可以定位一些有性能问题的sql... [阅读全文]

  • mysql从执行.sql文件时处理 换行的问题

    在备份数据库的时候,数据表中可能存在这样的值array('a'='b', 'c'='d') 这种格式的值。而在数据导出的时候 会将换... [阅读全文]

  • 基于Php mysql存储过程的详解

    实例一:无参的存储过程复制代码 代码如下:$conn = mysql_connect('localhost','root','roo... [阅读全文]

  • DROP TABLE在不同数据库中的写法整理

    drop table在不同数据库中的写法整理 1,mysql中 drop table if exists [table_... [阅读全文]

  • MySQL 事物

    需要了解更多数据库技术:mysql之多表查询,都可以关注数据库技术分享栏目---计算机技术网(www.ctvol.com)!

    事务是数据库处理操作,其中执行就好像它是一个单一的一组有序的工作单元。换言之,事务将永远不会是完全的,除非在组内每个单独的操作是成功的。如果事务中的... [阅读全文]

最近更新的文章
  • mysql数据表按照某个字段分类输出
  • MySQL基础知识和基本操作
  • 如何在两台Ubuntu linux上安装mysql server并配置主从复制?
  • 如何在CLASSPATH中配置MYSQL数据库驱动
  • 初学者从源码理解MySQL死锁问题
  • Linux命令文件查看讲解
  • 荐 任务3: Spark RDD读写HBase数据
  • mysql的启动过程详解
  • MySQL的查询计划中ken_len的值计算方法
  • linux上安装mysql5.7

推荐阅读

大家感兴趣的文章
  • 1 MySQL从删库到跑路(四)——MySQL数据库创建实例
  • 2 mysql-utilities 出现 No module named utilities
  • 3 在CentOS7上安装MySQL5.7-YUM源方式
  • 4 mysql8.0.21安装注意,尤其修改初始默认密码
  • 5 Linux error file 'boot_grub_i386-pc_normal.mod not found如何解决?
  • 6 macOS,安装+配置+激活:MySQL8.0 + Navicat Premium12
  • 7 CentOS7.4 源码安装MySQL8.0的教程详解
  • 8 有两个表A和B,均有key和value两个字段,如果B的key在A中也有,就把B的value替换为A中对应的value
  • 9 mysql 8.0.21 安装配置方法图文教程
  • 10 Centos8 环境下安装mysql-5.7

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/834999.html

(0)
上一篇 2021年9月25日 上午2:11
下一篇 2021年9月25日 上午2:15

精彩推荐