返回顶部
首页 > 资讯 > 数据库 >MySQL 常见的数据表设计误区汇总
  • 747
分享到

MySQL 常见的数据表设计误区汇总

MySQL设计误区MySQL数据表设计 2022-05-13 07:05:50 747人浏览 安东尼
摘要

目录误区一:过多的数据列误区二:过多的联合查询误区三:滥用 SET替代 ENUM误区四:生硬地避免NULL误区五:使用整数替换时间戳误区六:忘记字段的最大存储范围结语:误区一:过多的数据列 Mysql 存储引擎的

目录
  • 误区一:过多的数据列
  • 误区二:过多的联合查询
  • 误区三:滥用 SET替代 ENUM
  • 误区四:生硬地避免NULL
  • 误区五:使用整数替换时间戳
  • 误区六:忘记字段的最大存储范围
  • 结语:

误区一:过多的数据列

Mysql 存储引擎的 api 是按照行缓冲区方式从服务端和存储引擎复制数据。服务端将缓冲区数据解码成数据列。然而,将行缓冲区的格式转换为数据行数据结构的列可能会代价很高。MyISAM 固定使用与服务端匹配的行格式,因此无需转换。然而,MyISAM 的可变行格式以及 InnoDB 的行格式总是需要进行转换。转换的代价依赖于列的数量。如果当数据表的列超过上百列的时候,会引起很高的 CPU 资源消耗——即便是使用到的列很少。曾经看过一篇文章,指的是一个多语言的解决方案,直接简单粗暴地将系统支持的语言用对应的列表示,例如:


CREATE TABLE t_multi_language_news (
  id INT PRIMARY KEY,
  title_cn VARCHAR(32),
  title_en VARCHAR(32),
  title_it VARCHAR(32),
  ...
  content_cn VARVHAR(256),
  content_en VARCHAR(256),
  conntent_it VARCHAR(256),
);

这种方式随着系统支持的语言越多,数据表的列越多,最终导致性能严重下降。如果你设计一个数据表的列数量超过100时,就需要考虑你的设计是否合理了。 **应对方式:**首先是考虑业务本身的设计是否合理,如果确实一个实体需要很多字段来描述,那么可以拆分数据表,通过扩展信息表来做。举个例子,对于资讯类的数据表,因为内容一般占据的空间会比较大,但是在列表不会直接查看,就可以拆成资讯主表和资讯详情表,主表存储标题、时间、摘要、缩略图附件 id 等列表要查看的信息即可。而资讯详情可以存储资讯的内容、来源、原文链接等信息。

误区二:过多的联合查询

mysql 一次联合查询最多只能61张表。而有些设计主张不做冗余字段设计,这会导致复杂业务时需要连接多张表查询。即便是联合的表数量低于61个,也会引起性能的下降,而且整个 sql 语句的维护将变得十分困难。作为一个设计的首要原则,就是如果想追求速度的话,一次查询不要跨太多的数据表做联合查询,尤其面临高并发场景的时候。 **应对方式:**首先,对于确定不会改变的字段,可以考虑冗余字段的方式减少联合查询。例如,一家企业的所属省份信息,就可以把省份代码、省份名称冗余了,而无需再通过省份代码去查询省份名称。其次,确实需要查其他表的情况下,可以考虑使用分步查询的方法,通过应用程序完成数据的组装,这种效率在数据表很多的时候会更高效,而且代码也更好维护。 误区三:万能的枚举 例如下面这种表设计:


CREATE TABLE t_countries (
  ...
  country ENUM('', '1', '2', ..., '45'),
  ...
);

这种方式本来可以通过一个以整数为 key的字典的查找表实现。如果是业务上增加了一个枚举,意味着整个表都需要使用 ALTER TABLE更新。而如果是使用应用代码的查找表,只需要增加新的键值对就好了。 **应对方式:**如果枚举确定不会变动(例如性别),那么没问题。如果枚举可能会增加,那么尽可能地通过应用程序来实现。

误区三:滥用 SET替代 ENUM

枚举ENUM 类型是数据表列的值只能是值集合中的一个,而 SET 类型是该列可以有一个或多个值。如果确定一个列只会有一个值,那么就应该优先使用枚举,而不是集合。例如下面的例子就是典型的滥用:


CREATE TABLE t_payment_way (
  ...
  is_default SET('Y', 'N') NOT NULL DEFAULT 'N',
  ...
);

很显然,is_default 要么是 Y,要么是 N,因此这里应该使用 ENUM。 **应对方式:**从业务层面考虑列的值是不是可能有多个,如果只有1个可选值那么就用 枚举ENUM。

误区四:生硬地避免NULL

很多文章都讨论过尽可能地避免使用 NULL,对于大部分场景这是一个好的设计,我们可以通过0,空字符串,约定的值等来表示空值。然而,不要因为这个而生硬套用,如果是这个值本身就是一个无意义的值的时候,那么使用 NULL 可能更合适。例如,如果要是有-1代表一个无意义的整数,可能会导致代码很复杂,甚至可能引起 bug。例如下面的例子:


CREATE TABLE t_person (
  birthday DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
  ...,
);

将一个 DATETIME 类型的默认值设置为全部是0会很奇怪,假设我们要统计人员的年龄平均值的时候,会引起莫名其妙的问题,而这种场景使用 NULL 就不会纳入到统计中来。可以通过设置 MySQL 的 SQL_MODE 参数禁止使用无意义的日期,避免出现这种情况。 **应对方式:**设计表的时候可以尽量使用 NOT NULL 避免空值,但是不要过于生硬,对于有些字段使用默认值无法表名意义或与实际不符时,也是可以选择使用 NULL 列的。只是,需要注意索引列不要使用NULL。而实际上,绝大部分索引列不太可能会是 NULL。

误区五:使用整数替换时间戳

之前有讲到过时间格式如何选择的问题,实际上有些开发者会使用整数来存储时间戳,他们的理由是这样效率更高。从某种意义上来说,可能会提高一点效率,但是帮助不大,因为在 MySQL 内部DATETIME 和 TIMESTAMP 本身就是用整数存储的。而如果使用整数存储时间的话,意味着应用程序中需要做时间转换,或者是 SQL 语句要对指定的字段进行时间转换,带来的收益可能得不偿失。 **应对方式:**尽可能地使用 DATETIME 存储时间,如果需要存储秒级精度一下的时间,那么可以考虑使用 BIGINT 来存储。

误区六:忘记字段的最大存储范围

在实际中设计表的时候会忘记数据类型的存储范围,比如使用 TINYINT(2)并不是只能存储两位整数,实际TINYINT(2) 可以存储的范围是-128-127。 存储超过255的整数。这种错误在使用整数类型的时候很容易出现问题,在插入整数的时候,MySQL 不会检查实际的整数位数,而是按对应存储字节数的范围存入,这种情况假设不注意会存入无意义的值。例如下面的 INSERT 操作会成功,而我们可能误以为 TINYINT(2)只能存储2位整数:


CREATE TABLE t_int_test (
    id INT PRIMARY KEY,
    number TINYINT(2)
);

INSERT INTO t_int_test (id, number) VALUES (3,123);

应对方式:在应用程序中做数据校验。

结语:

在实际设计数据表的过程中,除了需要考虑每个字段的数据类型之外,还需要考虑存储空间大小。对于常用的一些字段,如时间、标题、备注等,最好是内部形成一定的规范,大家遵照规范执行,并且增加校验能够避免很多问题。

以上就是MySQL 常见的数据表设计误区汇总的详细内容,更多关于MySQL 数据表设计误区的资料请关注自学编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL 常见的数据表设计误区汇总

本文链接: https://lsjlt.com/news/10400.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL 常见的数据表设计误区汇总
    目录误区一:过多的数据列误区二:过多的联合查询误区三:滥用 SET替代 ENUM误区四:生硬地避免NULL误区五:使用整数替换时间戳误区六:忘记字段的最大存储范围结语:误区一:过多的数据列 MySQL 存储引擎的 ...
    99+
    2022-05-13
    MySQL 设计误区 MySQL 数据表设计
  • MySQL中常见的数据表设计误区有哪些
    这篇文章将为大家详细讲解有关MySQL中常见的数据表设计误区有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。误区一:过多的数据列MySQL 存储引擎的 API 是按照行缓冲区方式从服务端和存储引擎复制...
    99+
    2023-06-15
  • Java常见知识点汇总(①)——数据类型
    一. Java中的数据类型变量就是申请内存来存储值。也就是说,当创建变量的时候,需要在内存中申请空间。内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据。 因此,通过定义不同类型的变量,可以在内存中储存整数、小数...
    99+
    2023-06-05
  • MySQL中常见的几种日志汇总
    前言: 在 MySQL 系统中,有着诸多不同类型的日志。各种日志都有着自己的用途,通过分析日志,我们可以优化数据库性能,排除故障,甚至能够还原数据。这些不同类型的日志有助于我们更清晰的了解数据库,在日常学习及运维过程...
    99+
    2022-05-11
    mysql常见日志 mysql常见日志有哪些 mysql 日志
  • PHP设计模式:常见误区与陷阱
    php 中设计模式虽有优势,但使用时也存在误区和陷阱,例如盲目使用、违反单一职责原则、混淆继承与委托、滥用工厂方法模式和错误的 solid 原则实施。正确应用设计模式,如通过职责链模式分...
    99+
    2024-05-14
    php 设计模式
  • 初学者必须知道的MySQL数据库常见问题汇总
    本篇内容介绍了“初学者必须知道的MySQL数据库常见问题汇总”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!...
    99+
    2024-04-02
  • MySQL必备的常见知识点汇总整理
    本文实例总结了MySQL必备的常见知识点。分享给大家供大家参考,具体如下: 最近在整理 sql 的时候发现一份优秀的笔记,是原作者学习 sql 所做的笔记,分享这份总结给大家,对大家对 sql 的可以来一次全方位的...
    99+
    2022-05-28
    MySQL 知识点
  • python正则表达式常见的知识点汇总
    目录一、介绍二、查找方法的使用1、match方法(只匹配字符串开头)2、search方法(扫描整个字符串,找到第一个匹配)3、re.match与re.search的区别4、finda...
    99+
    2024-04-02
  • Excel数据导入Mysql常见问题汇总:如何处理数据丢失的情况?
    Excel数据导入MySQL常见问题汇总:如何处理数据丢失的情况?在将Excel表格中的数据导入到MySQL数据库时,经常会遇到数据丢失的情况。这可能是由于数据格式不匹配、导入程序错误或其他原因导致的。下面将介绍一些处理数据丢失情况的常见问...
    99+
    2023-10-22
    Excel MySQL 数据丢失
  • Excel数据导入Mysql常见问题汇总:如何处理导入数据时遇到的错误日志问题?
    Excel数据导入Mysql常见问题汇总:如何处理导入数据时遇到的错误日志问题?导入Excel数据到MySQL数据库是一项常见的任务。然而,在这个过程中,我们经常会遇到各种错误和问题。其中之一就是错误日志问题。当我们尝试导入数据时,系统可能...
    99+
    2023-10-22
    错误日志 处理 数据导入
  • 数据库设计的误区有哪些
    这篇文章主要介绍“数据库设计的误区有哪些”,在日常操作中,相信很多人在数据库设计的误区有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”数据库设计的误区有哪些”的疑惑有所帮...
    99+
    2024-04-02
  • Excel数据导入Mysql常见问题汇总:如何处理数据格式转换的问题?
    Excel数据导入Mysql常见问题汇总:如何处理数据格式转换的问题?导入Excel数据到MySQL数据库是一种常见的数据迁移方式,但在这个过程中经常会遇到数据格式转换的问题。本文将为读者总结一些常见的数据格式转换问题,并提供解决方案。日期...
    99+
    2023-10-22
    Excel MySQL 数据格式转换
  • golang函数与goroutine的常见误区
    常见的 go 语言函数和 goroutine 误区:共享变量并发访问:避免在 goroutine 中修改共享变量,使用互斥锁或读写锁保证安全访问。未闭合 channel:使用后及时关闭 ...
    99+
    2024-04-25
    golang 并发访问 同步机制
  • js数组去重常见的方法汇总(7种)
    目录1、借助ES6提供的Set结构 new Set() 简单好用 强烈推荐2、利用 filter() 去重3、利用for 循环 搭配 indexOf 去重4、将数组的每一个元素依次与...
    99+
    2024-04-02
  • Python 数据分析的迷思:揭穿常见误区
    真相:Python 具有强大的数据处理库,例如 NumPy、Pandas 和 Dask,可以高效地处理数百万甚至数十亿行的数据。 迷思 2:Python 速度慢 真相:虽然 Python 通常比编译语言(如 C++ 和 Java)慢,但它...
    99+
    2024-03-12
    迷思 1:Python 无法处理大型数据集
  • Excel数据导入Mysql常见问题汇总:如何处理导入过程中的重复数据?
    Excel数据导入Mysql常见问题汇总:如何处理导入过程中的重复数据?在数据处理的过程中,我们常常会遇到Excel数据导入到Mysql数据库的需求。然而,由于数据量庞大,很容易出现重复数据的情况,这就需要我们在导入过程中进行相应的处理。在...
    99+
    2023-10-22
    数据过滤 数据匹配 去重处理
  • mysql 数据库表错误 修复 总结
    mysql 数据库坏表修复    萝卜白菜,各有所爱,能干活、能修复表才是王道!!!修复之前谨记:先备份数据库 (备份完成后再进行以下修复操作)   可以mysqldump ...
    99+
    2024-04-02
  • Java 打包同步问题汇总:如何解决常见的错误?
    在 Java 开发中,我们经常需要将程序打包成 JAR 或 WAR 文件,以便于部署和分发。但是在打包过程中,常常会遇到同步问题,例如有些文件没有被打进包里,或者打进去的文件和实际需要的文件不一致等等。本文将对这些常见的问题进行汇总,并提...
    99+
    2023-06-20
    打包 同步 unix
  • MySQL数据库连接异常汇总(值得收藏)
    在Centos上部署项目发现一个奇怪的问题,数据库连接一直抛异常。于是花了两个小时搜了各种数据库连接异常导致的原因,最终问题得以解决。同时,把解决过程中搜集到的异常信息汇总一下,当大家遇到类似的问题时,给大家以思路。...
    99+
    2022-05-31
    MySQL 连接 MySQL 连接异常
  • 一文总结JavaScript中常见的设计模式
    目录设计原则什么是设计模式一、单例模式二、策略模式三、代理模式四、迭代器模式五、发布-订阅模式六、命令模式七、组合模式八、模板方法模式九、享元模式十、职责链模式十一、中介者模式十二、...
    99+
    2023-05-19
    JavaScript设计模式 JavaScript设计
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作