mysql表设计

表设计流程:
(1)分库:根据模块分
(2)分表:根据流程分表
(3)冗余字段和视图设计
21个表设计准则

(1)命名规范
account_no,account_number
表名用t_user,视图用v_i,字段名:表名_字段名
外键:表名_字段名$1
主键索引:pk_name,唯一索引:uk_name,一般索引:idx_name
(2)选择合适的字段类型
选小的类型:tinyint,smallint,int,bigint
小数,金额选择:decimal,不要使用float和double。
TABLE invoices (
invoice_id INT PRIMARY KEY,
amount DECIMAL(10, 2)
);

在上述示例中,amount列可以存储最多10位数字,其中2位用于小数部分。
精确度和舍入:DECIMAL类型确保数据的精确度,不会导致浮点数的精度问题。任何插入或计算的结果都将按照指定的精度进行四舍五入。
存储的字符串长度相似,尽量使用char定长。
varchar不预先分配空间,长度不要超过5000,如果过大,建议修改类型为text,并且单独抽出一个表,用外键对应。
在一张表中,varchar指定了最大长度的和不能超过65535,超过使用text。
尽管分配了最大长度的内存,但VARCHAR列实际上只会占用实际存储的字符数加上一些额外的字节用于存储长度信息。这意味着如果您在
VARCHAR(50)列中存储了一个只有10个字符的字符串,它只会占用10个字符的存储空间,而不会占用50个字符的存储空间。
在MySQL和许多其他关系型数据库管理系统中,TEXT是一种用于存储长文本数据的数据类型。TEXT数据类型适用于存储大块文本,例如文章、评论、日志、文章内容等等。以下是关于TEXT数据类型的一些关键信息:
1.数据类型分类
:TEXT是一种文本数据类型,通常被分为不同的子类型,根据最大允许的文本长度,可以分为以下几种子类型:

  • TINYTEXT
  • TEXT
  • MEDIUMTEXT
  • LONGTEXT
    2.存储方式
    :TEXT列的数据以二进制形式存储,因此可以容纳各种字符,包括文本、二进制数据或格式化文本,如XML或JSON。
    3.用途
    :TEXT通常用于存储大段的自由文本,例如文章内容、博客帖子、评论等,以及需要较长文本描述的应用程序。
    4.性能考虑
    :由于TEXT列存储大量数据,因此在查询和检索大型TEXT列的数据时可能会对性能产生影响。在处理大文本数据时,您应该考虑合理的索引策略以提高查询性能。
    5.示例
    :以下是一个创建包含TEXT列的表的示例:
    sqlCopy codeCREATE TABLE articles (
    article_id INT PRIMARY KEY,
    title VARCHAR(255),
    content TEXT
    );

在上述示例中,content列用于存储文章的内容,可以容纳大段文本。
总之,TEXT是一种用于存储长文本数据的数据类型,它适用于需要存储大块文本的情况,如文章、评论等。根据您的需求,可以选择不同子类型的TEXT,以满足文本长度的要求。
(3)要选择毫无意义而独立不重复的数字作为主键
比如Auto_increment或者UUID,雪花算法生成的主键。
(4)字段长度选择2的幂次
(5)核心业务不使用物理删除,而是使用逻辑删除
(6)给表添加通用字段
id(主键),create_time,modified_time/update_time,version(用于乐观锁,非必须),remark(备注,非必须),modified_by(修改人,非必须),creator(创建人,非必须)
(7)表中列太多会影响性能,不超过20个
(8)尽量使用not null
(9)考虑哪些列需要加索引
一个表单索引不超过5个,过多会降低写速度。
加在区分度高的列。
(10)三大范式的合理使用
第一范式:字段的原子性
第二范式:所有列都和主键直接相关
第三范式:字段没有冗余,不存在传递依赖。
我们可以通过违反第三范式,添加和主键不是直接相关的冗余数据,从而减少表的数量。
比如:手机,单价,数量,总金额,总金额能通过单价和数量算出来。
(11)不做外键关联,外键概念需要在应用层解决。
(12)使用innodb
(13)使用utf8字符集
(14)枚举需要注释清楚
(15)时间类型的选择:
date,2023-2-2
time,8:30:23
datetime:2023-2-2 8:30:23,和时区无关
timestamp:和时区有关
year:2012
优先选择datetime
(16)不建议使用存储过程和触发器
(17)将多对多表关系,修改为一对多
通过将两个表变为三个表,从而将多对多改为一对多。
比如:学生和课程。通过新建一个学生-课程表,外键关联学生id和课程id,从而实现一对多。
(18)提前考虑分库分表
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/385945.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ChatGPT高效提问—prompt实践

ChatGPT高效提问—prompt实践 ​ 探索prompt在实际生活中的各种应用,旨在帮助理解和掌握如何将之前学到的prompt基础和技巧应用到具体实践中,从而在各个领域实现人工智能的价值。 ​ 通过生动的案例,发现并挖掘ChatGPT和prompt的无穷潜力。…

华为机考入门python3--(12)牛客12-字符串反转

分类:字符串 知识点: 字符串是否为空 if not my_str 字符串逆序 my_str[::-1] 题目来自【牛客】 def reverse_string(s): # 判断字符串是否为空或只包含空格 if not s.strip(): return "" # 使用Python的切片语法反转字符串 re…

(AtCoder Beginner Contest 334) --- F - Christmas Present 2 -- 题解

F - Christmas Present 2 F - Christmas Present 2 题目大意: 思路解析: 因为他是顺序前往每个孩子的家,前往时必须要带一个礼物,并且最多只能带k个礼物,所以它每次前往最多k个孩子之后就要回到初始点重新出发。…

Java毕业设计-基于ssm的仓库管理系统-第77期

获取源码资料,请移步从戎源码网:从戎源码网_专业的计算机毕业设计网站 项目介绍 基于ssm的仓库管理系统:前端jsp、jquery、bootstrap,后端 maven、springmvc、spring、mybatis,集成库存管理、出入库管理、供应商信息…

计算机毕业设计 | vue+SpringBoot选课管理系统(附源码)

1,绪论 1.1 开发背景 随着我国高等教育的发展,数字化校园将成为一种必然的趋势,国内高校迫切需要提高教育工作的质量与效率,学生成绩管理工作是高校信息管理工作的重要组成部分,与国外高校不同,他们一般具…

如何采集抖音的视频-简数采集器

如何使用简数采集器批量采集抖音的视频和相关信息呢? 简数采集器目前不支持采集和下载抖音的视频,且不建议采集,请换个采集源采集。 简数采集器采集网页特别简单,不需要懂技术研究代码的,只要输入采集的网址&#xf…

视觉开发板—K210自学笔记(六)

视觉开发板—K210 本期我们继续来遵循其他控制器的学习路线,在学习完GPIO的基本操作后,我们来学一个非常重要的UART串口通信。为什么说这个重要呢,通常来说我们在做一个稍微复杂的项目的时候K210作为主控的核心可能还有所欠缺,另…

数据结构与算法:二叉树(前中后三种遍历的递归和非递归原理和板子、判断是否为搜索二叉树BST、完全二叉树、满二叉树、平衡二叉树)

二叉树递归遍历原理 递归序 很有意思的一个全新的角度:从递归序去看前中后三种遍历。 首先来看一颗二叉树: 和其遍历的函数 public static void recurtion(Node head){//第一步入口if(headnull) return;//第一步出口//第二步入口recurtion(head.left…

第七篇:SQL语法-DML-数据操作语言

DML英文全称是Data Manipulation Language(数据操作语言),用来对数据库中表的数据记录进行增删改操作。它主要包含以下操作, 添加数据(INSERT)修改数据(UPDATE)删除数据(DELETE) 一,添加数据(INSERT) 注意: 插入数据时&#xff0c…

LeetCode:70.爬楼梯

前言:好家伙,一直以为动态规划是啥高大上的,解释那么多,在我看来不过是找规律罢了, 写那么多"专业术语"咋看咋像糊弄人的 (手动扶额) 另外,通项公式虽然抽象还能接受,但是矩阵快速幂…

08:K8S资源对象管理|服务与负载均衡|Ingress

K8S资源对象管理|服务与负载均衡|Ingress DaemonSet控制器污点策略容忍容忍污点 其他资源对象Job资源对象 有限生命周期CronJob资源对象 集群服务服务自动发现headless服务 实现服务定位与查找 服务类型 Ingress插件 发布服务的方式 DaemonSet控制器 Da…

洛谷: P9749 [CSP-J 2023] 公路

思路: 贪心思想指的是在对问题求解的时候,总是能做出在当前看来是最好的选择,也就是说,如果要得到整个问题的最优答案,那么要求每一步都能做出最好的选择(feihua)。 在这道题里面,我们希望在来到第i站的时…

iTop-4412 裸机程序(十九)- 按键中断

目录 0.源码1.异常向量表1.1 原理1.2 异常种类1.3 ARMv7 规定的异常向量表 2. 中断2.1 iTop-4412 中使用的中断相关寄存器 上篇博文介绍了按键的轮询处理方式,本篇介绍按键的中断方式。 0.源码 GitHub:https://github.com/Kilento/4412NoOS 1.异常向量…

微信小程序(四十四)鉴权组件插槽-登入检测

注释很详细,直接上代码 新增内容: 1.鉴权组件插槽的用法 2.登入检测示范 源码: app.json {"usingComponents": {"auth":"/components/auth/auth"} }app.js App({globalData:{//定义全局变量isLoad:false} })…

C++ Qt框架开发 | 基于Qt框架开发实时成绩显示排序系统(1)

目标:旨在开发一个用户友好的软件工具,用于协助用户基于输入对象的成绩数据进行排序。该工具的特色在于,新输入的数据将以红色高亮显示,从而直观地展现出排序过程中数据变化的每一个步骤。 结果展示: 本程序是一个基于…

在Ubuntu22.04上部署FoooCUS2.1

Fooocus 是一款基于 Gradio的图像生成软件,Fooocus 是对 Stable Diffusion 和 Midjourney 设计的重新思考: 1、从 Stable Diffusion 学习,该软件是离线的、开源的和免费的。 2、从 Midjourney 中学到,不需要手动调整,…

嵌入式Qt 计算器界面设计代码重构

一.计算器界面设计代码重构 计算器界面设计:嵌入式Qt 计算器界面设计-CSDN博客 重构的概念: 代码实现与代码重构的不同: 软件开发过程: 什么样的代码需要重构: 计算器界面代码重构的框架设计: 实验&#…

理解JAVA命名和目录接口(JNDI)

理解JAVA命名和目录接口(JNDI) 考虑访问网站的场景,Web用户要求记住四字节的IP地址而不是有意义的名称。例如,假设Web用户用123.23.3.123而不是hotmail.com访问hotmail网站。在这种情形下,Web用户难以记住不同的IP地址来访问不同的网站。因此,要使其变得对Web用户简单方…

Unity下使用Sqlite

sqlite和access类似是文件形式的数据库,不需要安装任何服务,可以存储数据,使用起来还是挺方便的。 首先需要安装DLL 需要的DLL 我们找到下面两个文件放入Plugins目录 Mono.Data.Sqlite.dll System.Data.dll DLL文件位于Unity的安装目录下的…

分布式文件系统 SpringBoot+FastDFS+Vue.js

分布式文件系统 SpringBootFastDFSVue.js 一、分布式文件系统1.1.文件系统1.2.什么是分布式文件系统1.3.分布式文件系统的出现1.3.主流的分布式文件系统1.4.分布式文件服务提供商1.4.1.阿里OSS1.4.2.七牛云存储1.4.3.百度云存储 二、fastDFS2.1.fastDSF介绍2.2.为什么要使用fas…
最新文章