JavaWeb——MySQL-多表设计(1/5):一对多(引言、一对多关系案例、分析表结构设计、一对多关系总结)

目录

引言

一对多关系案例

需求分析

表结构设计

一对多关系总结


引言

多表设计背景

        在项目开发中,数据库表结构设计依据页面原型和需求文档,分析业务模块关系。业务关联使表结构间存在联系,常见关系有一对一、多对多和一对多(一对多与多对一实质相同)。接下来将重点讲解这三种关系,先从一对多关系入手,以部门及员工模块表结构设计为例进行阐述。

一对多关系案例

部门与员工表设计

一对多关系实现:在数据库表中多的一方,添加字段,来关联一的一方的主键。

需求分析

  • 部门管理

        页面原型中部门管理页面展示部门名称和最后操作时间(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课程 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值