数据库-多表设计

概述:

项目开发中,在进行数据库表结构设计时,会根据业务需求及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各个表结构之间也存在着各种联系,基本分为三种:

一对多

多对多

一对一

一对多

根据页面原型及需求文档,完成部门及员工模块的表结构设计

外键约束(语法)

创建表时指定

create table 表名(

字段名 数据类型,

...

constraint 外键名称 foreign key (外键字段名) references 主表(字段名);


建完表后,添加外键

alter table 表名 add constraint 外键名称 foreign (外键字段名) referness主表(字段名);

缺点:

影响增、删、改的效率

仅用于单节点数据库,不适用于分布式,集群场景

容易引发数据库的死锁问题,消耗性能

一对一

关系:一对一关系,多用于单表拆分,将一张表的基础字段放在一张表中,其他字段放在另一张表中,其他字段放在另一张表中,以提升效率

实现:在任意一方加入外键,关联另一方的主键,并且设置外键为唯一的(UNIQUE)

多对多

**关系:**一个学生可以选修多门课程,一门课程也可以被多个学生选择

实现:建立第三张中间表,中间表至少包含两个外键,分别关联两方主键

相关推荐
TDengine (老段)17 分钟前
TDengine 逻辑计划生成 — 从 AST 到关系代数算子树
大数据·数据库·物联网·wpf·时序数据库·tdengine·涛思数据
折戟不必沉沙29 分钟前
mysql忘记密码
数据库·mysql
kuonyuma39 分钟前
MyBatis入门·注解操作
java·spring boot·mysql·spring·mybatis
聪明努力的积极向上41 分钟前
【claude code】MySQL MCP 配置完整指南
数据库·mysql·ai编程
AC赳赳老秦42 分钟前
OpenClaw + 阿里云 OSS 自动化:批量上传下载文件、自动备份本地数据到云端
运维·数据库·阿里云·自动化·云计算·deepseek·openclaw
数智化管理手记42 分钟前
三步轻量化落地法!精益赋能数字化,让工厂转型告别形式化
运维·数据库·人工智能·精益工程
又至冬日1 小时前
鸿蒙(HarmoneyOS),封装一个通用关系型数据库操作类
数据库·oracle·harmonyos
Nontee1 小时前
新手数据库避坑指南:通俗理解“页分裂”与“数据碎片”
数据库·oracle
DIY源码阁1 小时前
JavaSwing酒店管理系统 - MySQL版
java·mysql·eclipse
川石课堂软件测试1 小时前
UI自动化测试|元素操作&浏览器操作实践
功能测试·测试工具·mysql·ui·docker·容器·单元测试