当前位置: 首页 > article >正文

SQL 第二篇:表结构设计(为什么企业要拆成 3 张表)

一、前言上一篇我们已经完成了 CRUD。但是你会发现一个问题用户的信息越来越多比如用户名密码手机号邮箱性别生日收货地址默认地址省市区这时候很多初学者会这样干全部塞进 user 表最后 user 表会越来越臃肿。所以这一篇我们正式进入❗ 表结构设计建模这一步才是真正开始接近企业开发。二、企业为什么不能只用一张 user 表很多人最开始会这样设计CREATE TABLE user ( id BIGINT PRIMARY KEY AUTO_INCREMENT, username VARCHAR(64), password VARCHAR(128), phone VARCHAR(20), email VARCHAR(100), real_name VARCHAR(50), province VARCHAR(50), city VARCHAR(50), detail_address VARCHAR(200) );看起来没问题。但实际上账号信息用户资料收货地址是三种完全不同的数据。三、企业里的真实做法拆表所以企业里通常会拆成user 用户主表user_detail 用户详情表user_address 用户地址表这样设计后结构更清晰更容易扩展更符合业务划分查询性能更稳定四、第一张表user用户主表1. 建表语句CREATE TABLE user ( id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT 主键ID, username VARCHAR(64) NOT NULL UNIQUE COMMENT 用户名, password VARCHAR(128) NOT NULL COMMENT 密码, create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 创建时间, update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT 更新时间 );2. 这张表存什么这一张表只存登录相关信息比如用户名密码时间它是账号体系核心表五、重点字段讲解企业必须懂1️⃣ id主键id BIGINT PRIMARY KEY AUTO_INCREMENT含义每条数据唯一标识为什么用 BIGINT因为企业数据量可能很大。INT 最大约 21 亿 BIGINT 更安全所以很多企业直接统一主键默认 BIGINTAUTO_INCREMENT 是什么表示主键自动增长插入第一条id 1第二条id 2数据库自动维护。六、username 为什么 UNIQUEusername VARCHAR(64) NOT NULL UNIQUE重点UNIQUE 唯一索引意味着用户名不能重复比如zhangsan只能有一个。否则会报错。七、password 为什么 VARCHAR(128)很多人会问密码不是123456吗 为什么128因为企业里不会直接存明文密码。而是加密后的字符串比如BCrypt MD5 SHA加密后长度会很长。所以一般VARCHAR(128)甚至更大。八、create_time 和 update_time企业高频1️⃣ create_timecreate_time DATETIME DEFAULT CURRENT_TIMESTAMP表示数据创建时间插入时自动生成。2️⃣ update_timeupdate_time DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP表示数据更新时间每次 UPDATE 自动刷新。九、第二张表user_detail用户详情表1. 建表语句CREATE TABLE user_detail ( id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT 主键ID, user_id BIGINT NOT NULL UNIQUE COMMENT 用户ID, real_name VARCHAR(50) COMMENT 真实姓名, phone VARCHAR(20) COMMENT 手机号, email VARCHAR(100) COMMENT 邮箱, gender TINYINT DEFAULT 0 COMMENT 性别0-未知 1-男 2-女, birthday DATE COMMENT 生日, create_time DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT 创建时间, update_time DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT 更新时间 );十、为什么拆出 user_detail因为用户资料 ≠ 登录信息很多业务里登录频率很高但是用户资料很少修改所以企业通常会拆表。十一、这里最关键的字段user_iduser_id BIGINT NOT NULL UNIQUE这个字段是❗ user_detail 属于哪个 user为什么 UNIQUE因为一个用户只有一份详情所以user 1 —— 1 user_detail这就叫一对一关系十二、第三张表user_address用户地址表1. 建表语句CREATE TABLE user_address ( id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT 主键ID, user_id BIGINT NOT NULL COMMENT 用户ID, receiver_name VARCHAR(50) NOT NULL COMMENT 收货人姓名, phone VARCHAR(20) NOT NULL COMMENT 收货人电话, province VARCHAR(50) NOT NULL COMMENT 省, city VARCHAR(50) NOT NULL COMMENT 市, district VARCHAR(50) NOT NULL COMMENT 区/县, detail_address VARCHAR(200) COMMENT 详细地址, is_default TINYINT DEFAULT 0 COMMENT 是否默认0-否 1-是, create_time DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT 创建时间, update_time DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT 更新时间, INDEX idx_user_id (user_id) );十三、为什么 user_address 不加 UNIQUE因为一个用户可以有多个地址比如家 公司 父母家所以同一个 user_id 可以出现多次这就是一对多关系十四、为什么加索引INDEX idx_user_id (user_id)因为后面经常会这样查SELECT * FROM user_address WHERE user_id 1;所以user_id 是高频查询字段企业里通常会加索引。十五、三张表关系核心最终关系user 和 user_detail 1对1user 和 user_address 1对多十六、核心这一篇最重要的不是语法。而是 开始理解“为什么企业要拆表” 数据库拆表规则最终笔记版❗ 总原则一张表只做一件事。-----------------------------------怎么判断一张表是不是“做了多件事”① 职责不同账号、资料、地址不是一类数据。② 出现一对多一个用户多个地址、多个订单。③ 字段太多一张表几十上百字段说明职责可能混乱。④ 修改频率不同高频修改字段不要影响核心主表。⑤ 出现大字段富文本、长内容、JSON 单独拆。⑥ 查询场景不同登录、用户中心、收货页关注的数据不同。----------------------------------- 最终本质拆表不是死记规则而是判断这张表是不是还只做一件事----------------------------------- 案例user→ 账号登录user_detail→ 用户资料user_address→ 收货地址账号 ≠ 资料 ≠ 地址所以拆表。十七、一句话总结企业数据库设计本质是按业务职责拆表而不是把所有字段塞进一张表。下一篇下一篇进入SQL 第三篇表关系设计user_id 到底是什么真正讲透一对一 一对多 外键 user_id以及为什么 JOIN 能把表拼起来

相关文章:

SQL 第二篇:表结构设计(为什么企业要拆成 3 张表)

一、前言上一篇我们已经完成了 CRUD。但是你会发现一个问题:用户的信息越来越多比如:用户名密码手机号邮箱性别生日收货地址默认地址省市区这时候很多初学者会这样干:全部塞进 user 表最后 user 表会越来越臃肿。所以这一篇,我们正…...

嵌入式系统中的高效数学运算实现与优化

1. 嵌入式数学运算的核心价值与挑战在资源受限的嵌入式系统中,数学运算的实现方式直接决定了系统性能和精度。与通用计算机不同,嵌入式设备通常不具备硬件浮点运算单元(FPU),甚至某些低端微控制器连整数乘法指令都没有。这就迫使开发者必须在…...

PostgreSQL 是在运行吗?

PostgreSQL 运行了吗? 摘要: 本文提供了一份在 Linux 上检查 PostgreSQL 是否运行的故障排除指南,包括如何识别正确的实例和端口,以及在基于 Debian 和使用 Systemd 的发行版上启动 Postgres 的方法。 我在 Postgres 的 slack 和…...

网络工程师必备:Document_Buddy,命令行下的网络文档瑞士军刀

1. 项目概述:一个为网络工程师量身打造的文档伴侣如果你是一名网络工程师、运维人员,或者任何需要频繁与网络设备配置、日志、报告打交道的从业者,那么你肯定对下面这个场景不陌生:面对几十上百台设备的配置备份,你需要…...

告别手机小屏敲代码:用Termux配置SSH,实现电脑远程连接Android终端全攻略

告别手机小屏敲代码:用Termux配置SSH实现电脑远程连接Android终端全攻略 在咖啡厅用手机调试服务器代码,在地铁上突然需要紧急修复生产环境bug——这些场景对开发者来说早已不陌生。但盯着5英寸屏幕敲命令的痛苦,体验过的人都懂。Termux这个A…...

在多模型聚合场景下利用 Taotoken 实现智能降级与容灾

在多模型聚合场景下利用 Taotoken 实现智能降级与容灾 1. 多模型聚合架构的核心挑战 在构建高可用 AI 服务的场景中,依赖单一模型供应商存在明显的服务连续性风险。当某个主流模型服务出现暂时不可用时,缺乏备选方案的架构会导致核心业务功能中断。Tao…...

告别网盘限速烦恼:LinkSwift直链下载助手完整指南

告别网盘限速烦恼:LinkSwift直链下载助手完整指南 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云盘 / 天翼云盘…...

从噪音困扰到静音享受:Fan Control如何重塑你的Windows散热体验

从噪音困扰到静音享受:Fan Control如何重塑你的Windows散热体验 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Tr…...

全面解析“vcruntime140_1.dll丢失”问题:成因、本质与终极解决之道

在Windows系统上运行某些软件或游戏时,您可能会突然遭遇一个令人困扰的弹窗错误:“无法启动此程序,因为计算机中丢失 vcruntime140_1.dll。尝试重新安装该程序以解决此问题。” 这个错误不仅会中断您的工作或娱乐,其背后的原因也多…...

FastAPI-Admin:快速构建管理后台的声明式框架实战指南

1. 项目概述:一个为FastAPI应用快速构建管理后台的利器如果你正在用FastAPI开发一个Web应用,无论是内部的管理系统、内容发布平台,还是带有复杂数据模型的业务后台,迟早会面临一个绕不开的需求:需要一个界面友好、功能…...

后级DCAC核心控制算法设计

3.2.3 并网逆变控制软件详细设计1 参数与平台额定并网功率:50kW短时离网最大功率:80kW(60s)电网:三相四线,线电压380V 10%,频率50Hz 0.5Hz直流母线电压:900V(由前级光伏B…...

Intel两项关键人事任命:Alex Katouzian、Pushkar Ranade助力客户端计算与物理AI突破

Alex Katouzian:从高通到Intel,掌舵客户计算与物理AI近日,Intel官方宣布Alex Katouzian出任客户计算与物理AI部门执行副总裁兼总经理。Katouzian此前在高通担任移动、计算及XR部门负责人,以技术洞察与规模化执行能力著称。他将于5…...

SPICE模型基础与符号封装全流程解析

1. SPICE模型基础与工程价值在电子设计自动化(EDA)领域,SPICE(Simulation Program with Integrated Circuit Emphasis)模型如同电路设计师的"数字实验室"。这种基于文本的模型文件通过非线性微分方程组精确描述电子元件的电气特性&…...

Python代码质量:从规范到自动化检查

Python代码质量:从规范到自动化检查 1. 技术分析 1.1 代码质量维度 维度描述工具代码风格PEP 8规范black, isort类型检查类型注解检查mypy代码规范最佳实践flake8, pylint安全检查潜在漏洞bandit, safety测试覆盖代码测试比例coverage 1.2 工具对比 工具功能性能学习…...

基于气象站云层实测参数的光伏出力预测与新能源调度应用研究

在新型电力系统建设与新能源大规模接入背景下,光伏发电出力的波动性、间歇性已成为影响电网安全稳定运行、功率平衡及调度决策的关键因素。云层是影响地表太阳辐射强度最直接、最频繁的气象要素,气象站实时监测的云层覆盖度、云层高度、云底高度、云层类…...

JeecgBoot低代码平台:Java开发者如何用代码生成器提升企业级开发效率

1. 项目概述:一个面向企业级应用的低代码开发平台如果你是一名Java后端开发者,或者是一名中小型企业的技术负责人,那么你一定对“快速开发”这个词有着深刻的体会。业务需求变化快,市场窗口期短,但传统的Java企业级开发…...

终极指南:如何用开源工具免费获取八大网盘真实下载链接,告别客户端强制安装

终极指南:如何用开源工具免费获取八大网盘真实下载链接,告别客户端强制安装 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 /…...

AISMM模型不是万能钥匙?3类不可替代的传统规则引擎场景+混合架构设计图(附2024年金融AI模型淘汰预警清单)

更多请点击: https://intelliparadigm.com 第一章:AISMM模型在金融行业中的应用 AISMM(Adaptive Intelligent Sequential Modeling Mechanism)是一种面向时序决策场景的动态建模框架,专为高噪声、低延迟、强监管的金融…...

用TensorFlow和PyTorch搞定视频动作识别:手把手教你搭建时空卷积网络(附完整代码)

用TensorFlow和PyTorch搞定视频动作识别:手把手教你搭建时空卷积网络(附完整代码) 视频动作识别正成为计算机视觉领域的热门方向,从健身APP的自动计数到智能监控中的异常行为检测,这项技术正在改变我们处理动态视觉信息…...

立体匹配中的‘分组’艺术:GwcNet的Group-wise Correlation如何提升模型精度与效率

立体匹配中的‘分组’艺术:GwcNet的Group-wise Correlation如何重塑模型性能 在双目视觉的世界里,立体匹配算法一直试图回答一个核心问题:如何让机器像人类一样精准感知深度?2019年CVPR会议上亮相的GwcNet,用"分组…...

GameDocGenSkill:基于代码即文档理念的游戏设计自动化生成方案

1. 项目概述与核心价值最近在游戏开发社区里,一个名为“GameDocGenSkill”的项目引起了我的注意。这个项目由开发者 maqingwen2 发起,其核心目标直指一个困扰了无数游戏开发团队的老大难问题:如何高效、规范地生成和管理游戏设计文档。如果你…...

构建AI智能体成熟度公开蓝图:证据阶梯与有界自治实践

1. 项目概述:一份关于“有界智能体成熟度”的公开蓝图最近在整理一个内部项目时,我意识到一个普遍问题:我们如何向外界清晰、诚实地描述一个仍在发展中的AI智能体系统?是夸大其词,宣称“通用人工智能即将到来”&#x…...

从DDR3颗粒到FPGA引脚:一文拆解OCT(片内终端)的完整工作流程与寄存器配置

从DDR3颗粒到FPGA引脚:OCT阻抗匹配全流程与寄存器配置实战 在高速数字系统设计中,信号完整性从来不是选择题而是必答题。当FPGA与DDR3内存以数百MHz的频率交换数据时,每个上升沿都可能成为信号反射的"犯罪现场"。OCT(On…...

紧急!某城商行因Docker调试误操作导致T+0清算中断——这份《金融容器调试熔断 checklist》已获央行金融科技中心内部推荐

更多请点击: https://intelliparadigm.com 第一章:金融容器调试事故的根源与警示 在高并发、强一致性的金融核心系统中,容器化部署虽提升了弹性与交付效率,却也放大了调试环节的脆弱性。一次看似常规的 kubectl exec -it payment…...

Legacy-iOS-Kit终极指南:让旧iPhone/iPad重获流畅体验的完整解决方案

Legacy-iOS-Kit终极指南:让旧iPhone/iPad重获流畅体验的完整解决方案 【免费下载链接】Legacy-iOS-Kit An all-in-one tool to restore/downgrade, save SHSH blobs, jailbreak legacy iOS devices, and more 项目地址: https://gitcode.com/gh_mirrors/le/Legacy…...

构建AI资源智能索引:从知识图谱到语义检索的工程实践

1. 项目概述:一个AI索引的诞生与价值最近在折腾一个叫lmnr-ai/index的项目,名字听起来有点抽象,但它的内核其实非常直接:为AI时代的信息洪流,构建一个高效、智能的“导航地图”。简单来说,这就是一个专门为…...

如何免费让Windows电脑变身苹果AirPlay接收器:3步实现iPhone投屏

如何免费让Windows电脑变身苹果AirPlay接收器:3步实现iPhone投屏 【免费下载链接】airplay2-win Airplay2 for windows 项目地址: https://gitcode.com/gh_mirrors/ai/airplay2-win 还在为Windows电脑无法接收iPhone或iPad的AirPlay投屏而烦恼吗?…...

Cortex-R82异常处理与调试机制深度解析

1. Cortex-R82异常处理架构解析在嵌入式实时系统中,异常处理机制直接决定了系统的可靠性和响应速度。Cortex-R82作为面向汽车电子和工业控制的高性能实时处理器,其异常处理架构设计体现了三个核心特征:确定性响应:所有异常入口和返…...

基于MCP协议的自动化网络红队:八大数学模型赋能智能风险评估

1. 项目概述与核心价值如果你是一名安全工程师、威胁分析师,或者正在尝试将AI融入安全运营流程,那么你大概率和我一样,经历过这样的困境:面对海量的CVE公告、零散的威胁情报和复杂的网络拓扑,想要进行一次系统性的风险…...

5分钟掌握Unlock-Music:浏览器中一键解锁加密音乐文件

5分钟掌握Unlock-Music:浏览器中一键解锁加密音乐文件 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web 项目地址: https…...