目录
引言
多表设计背景
在项目开发中,数据库表结构设计依据页面原型和需求文档,分析业务模块关系。业务关联使表结构间存在联系,常见关系有一对一、多对多和一对多(一对多与多对一实质相同)。接下来将重点讲解这三种关系,先从一对多关系入手,以部门及员工模块表结构设计为例进行阐述。
一对多关系案例
部门与员工表设计
一对多关系实现:在数据库表中多的一方,添加字段,来关联一的一方的主键。
需求分析
- 部门管理
页面原型中部门管理页面展示部门名称和最后操作时间(update_time
)。新增部门时仅需录入部门名称,且部门名称必填、唯一,长度在 2 - 10 之间。
- 员工管理
员工表之前已设计部分,
现需完善归属部门字段。添加员工信息时需选择归属部门,员工应关联部门的 ID。
表结构设计
- 部门表(
tb_dept
)- 字段设计
id
:主键,无符号整数类型(UNSIGNED INT
),设置为主键约束(PRIMARY KEY
)并自增(AUTO_INCREMENT
)。name
:部门名称,字符串类型(VARCHAR
),长度最长为 10,添加唯一约束(UNIQUE
)及注释 “这是部门的名称”。create_time
:创建时间,与员工表对应字段类型一致(可参考之前员工表设计,假设为DATETIME
类型)。update_time
:修改时间,类型同创建时间(DATETIME
类型)。
- SQL 语句
- 字段设计
create table tb_dept
(
id int unsigned primary key auto_increment comment '主键ID',
name varchar(10) not null unique comment '部门名称',
create_time datetime not null comment '创建时间',
update_time datetime not null comment '修改时间'
) comment '部门表';
(表格数据放在末尾)
- 员工表(
tb_emp
)完善- 字段设计
- 新增
dept_id
字段:关联部门的 ID,类型与部门表id
字段一致(INT UNSIGNED
),添加注释 “这是归属的部门 ID”。
- 新增
- SQL 语句
- 字段设计
create table tb_emp
(
id int unsigned primary key auto_increment comment 'ID',
username varchar(20) not null unique comment '用户名',
password varchar(32) default '123456' comment '密码',
name varchar(10) not null comment '姓名',
gender tinyint unsigned not null comment '性别, 说明: 1 男, 2 女',
image varchar(300) comment '图像',
job tinyint unsigned comment '职位, 说明: 1 班主任,2 讲师, 3 学工主管, 4 教研主管',
entrydate date comment '入职时间',
dept_id int unsigned comment '部门ID',
create_time datetime not null comment '创建时间',
update_time datetime not null comment '修改时间'
) comment '员工表';
(表格数据放在末尾)
一对多关系总结
关系特点与表结构体现
一对多关系中,一个部门对应多个员工,一个员工只归属于一个部门。部门表为 “1” 的一方(父表),员工表为 “多” 的一方(子表)。
在数据库表结构层面,通过在子表(员工表)中增加关联父表(部门表)主键的字段(dept_id
)来实现这种关系。这样设计便于查询员工所属部门,如查询员工 “张无忌” 所属部门,可通过员工表中dept_id
关联部门表id
获取部门信息。
表格数据
insert into tb_dept (id, name, create_time, update_time)
values (1, '学工部', now(), now()),
(2, '教研部', now(), now()),
(3, '咨询部', now(), now()),
(4, '就业部', now(), now()),
(5, '人事部', now(), now());
INSERT INTO tb_emp
(id, username, password, name, gender, image, job, entrydate, dept_id, create_time, update_time)
VALUES (1, 'jinyong', '123456', '金庸', 1, '1.jpg', 4, '2000-01-01', 2, now(), now()),
(2, 'zhangwuji', '123456', '张无忌', 1, '2.jpg', 2, '2015-01-01', 2, now(), now()),
(3, 'yangxiao', '123456', '杨逍', 1, '3.jpg', 2, '2008-05-01', 2, now(), now()),
(4, 'weiyixiao', '123456', '韦一笑', 1, '4.jpg', 2, '2007-01-01', 2, now(), now()),
(5, 'changyuchun', '123456', '常遇春', 1, '5.jpg', 2, '2012-12-05', 2, now(), now()),
(6, 'xiaozhao', '123456', '小昭', 2, '6.jpg', 3, '2013-09-05', 1, now(), now()),
(7, 'jixiaofu', '123456', '纪晓芙', 2, '7.jpg', 1, '2005-08-01', 1, now(), now()),
(8, 'zhouzhiruo', '123456', '周芷若', 2, '8.jpg', 1, '2014-11-09', 1, now(), now()),
(9, 'dingminjun', '123456', '丁敏君', 2, '9.jpg', 1, '2011-03-11', 1, now(), now()),
(10, 'zhaomin', '123456', '赵敏', 2, '10.jpg', 1, '2013-09-05', 1, now(), now()),
(11, 'luzhangke', '123456', '鹿杖客', 1, '11.jpg', 1, '2007-02-01', 1, now(), now()),
(12, 'hebiweng', '123456', '鹤笔翁', 1, '12.jpg', 1, '2008-08-18', 1, now(), now()),
(13, 'fangdongbai', '123456', '方东白', 1, '13.jpg', 2, '2012-11-01', 2, now(), now()),
(14, 'zhangsanfeng', '123456', '张三丰', 1, '14.jpg', 2, '2002-08-01', 2, now(), now()),
(15, 'yulianzhou', '123456', '俞莲舟', 1, '15.jpg', 2, '2011-05-01', 2, now(), now()),
(16, 'songyuanqiao', '123456', '宋远桥', 1, '16.jpg', 2, '2010-01-01', 2, now(), now()),
(17, 'chenyouliang', '123456', '陈友谅', 1, '17.jpg', NULL, '2015-03-21', NULL, now(), now());
END
学习自:黑马程序员——JavaWeb课程