多对多表的设计小案例

多对多数据表设计

  场景模拟:

    员工与角色:一个员工可以扮演多个角色,一个角色可以被多个员工扮演

    三张表:  employee,role,(关系表)emp_role

        employee 中的eid,关联到关系表中的r_eid,然后可以找到和r_eid同一行的一个或多个r_rtype 利用r_rtype 又可以到role表中找到rtype对应的rname,这样从第一张表的员工id到中间表的绑定关联,根据中间表的rtype字段可以引用到第三章表(role)表中,从而获取role表中的rname。如下图:

  

 

DROP TABLE IF EXISTS emp_role;
DROP TABLE IF EXISTS employee;
DROP TABLE IF EXISTS role;

CREATE TABLE employee(
        eid            INT    PRIMARY KEY AUTO_INCREMENT,
        ename         VARCHAR(20),
        egender     CHAR(10),
        ephone         VARCHAR(30)
);

CREATE TABLE role(
        rtype        INT  PRIMARY KEY AUTO_INCREMENT,
        rname        VARCHAR(20)
);

CREATE TABLE emp_role(
        r_eid     INT,
        r_type    INT,
        
        CONSTRAINT pk_r_eid_type PRIMARY KEY(r_eid,r_type),
        CONSTRAINT fk_employee_emp_role FOREIGN KEY(r_eid) REFERENCES employee(eid),
        CONSTRAINT fk_role_emp_role FOREIGN KEY(r_type) REFERENCES role(rtype)
);


-- 增加员工信息
INSERT INTO employee(eid,ename,egender,ephone) VALUES(1002125,'李永强','','13849753654');
INSERT INTO employee(ename,egender,ephone) VALUES('冯美美','','13754896369');
-- 增加角色信息
INSERT INTO role(rtype,rname) VALUES(1,'高管');
INSERT INTO role(rname) VALUES('前台'),('保洁');
-- 增加关系信息
INSERT INTO emp_role(r_eid,r_type) VALUES(1002125,2),(1002125,3);

 

转载于:https://www.cnblogs.com/deepSleeping/p/9982473.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值