MySQL表设计时踩过的坑!

数据库 MySQL
有朋友在后台留言。希望我能说说我在数据库表设计时踩过的坑。那么,我们今天就来聊聊我在数据库表设计时踩过的坑,以及现在对数据库表设计的一点建议。希望能够帮助到你。

MySQL表设计踩过的坑!

前言

有朋友在后台留言。希望我能说说我在数据库表设计时踩过的坑。那么,我们今天就来聊聊我在数据库表设计时踩过的坑,以及现在对数据库表设计的一点建议。希望能够帮助到你。

utf8的锅

场景 : 之前在给客户做微商城时,需要保存微信的授权信息,此时就有一个nickname字段,在设计数据表时,潜意识的将表的存储格式设置为utf8,生产上线一段时间后偶尔出现保存异常。经分析,出现异常的原因是:用户nickname中有email表情符号。utf8格式的数据表存储不下导致。

经验提示: 在设计数据表时,一定要注意该字段存储的内容,如果允许设置表情,则一定不能使用utf8,而是使用utf8mb4。

选择合适的类型

在数据库表设计时,字段的类型还真不好设计,这里简单说说:

  1. 保存手机号的字段,用varchar(20)就已经足够了,就不应该设计为varchar(100),设置为varchar(100)只会消耗更多的存储以及内存开销,得不偿失啊!
  2. 保存Boolean类型,使用tinyint就够了,而不需要设计为int,甚至bigint。

数据类型设计的过大,就会造成没必要的浪费(磁盘,内存,CPU),最主要的是,这是一件费力不讨好的事情。

主外键字段类型不一致

主外键类型不一致,说起来,你可能会不相信,但在数据库表设计时,稍不留神,就不一致,埋下隐式类型转换的坑。如下:

用户表:

  1. create table t_base_user( 
  2. oid bigint(20) not null primary key auto_increment comment "主键", .... 

 

注意此时的主键oid为bigint(20)。

用户地址表:

 

  1. create table t_base_user_address( 
  2.  
  3. oid bigint(20) not null primary key auto_increment comment "主键"
  4.  
  5. user_id varchar(30) null comment "用户id" .... 
  6.  

你看,此时在t_base_user_address表中的user_id外键字段,设计时的却是varchar(30)。你可能觉得你不可能发生这样的错误,说出来也不怕你笑话,我就踩过好几次这样的坑,到***发现慢SQL了,才发现自己中了这样的坑!!!

注释

之前在数据库表设计时,就没有加注释的习惯,造成的直接后果是:数据库设计阶段一过,后续数据表的使用中,字段名就全靠猜了。我们写代码是知道注释是非常重要的,同样在设计数据库表时,注释也非常重要!一定要记住加注释,无论是表,还是字段,索引,都必须加上注释。

如:

 

  1. create table t_base_user( 
  2.  
  3. oid bigint(20) not null primary key auto_increment comment "主键", .... 
  4.  

 

已有表加注释

 

  1. alter table t_base_user modify oid bigint(20) not null primary key auto_increment comment "主键"; 

加注释时,还要注意的是:在一些需要计算的字段上,需要加上计算规则文档的链接。方便后续查找!

加索引

在之前的文章中也有说过,一个好的数据表设计,在一开始就应该考虑添加索引,这个阶段添加索引成本不仅***。而且还不给后续留下慢查询,甚至生产事故的隐患!索引怎么加,索引重不重要,可以查看《写会MySQL索引》一文进行查看!唉,我就吃过不少没加索引或忘记添加索引的亏,记忆犹新!!!

小结

以上是我数据库设计表时躺过的坑,下面小结精简版本一下:

  • 允许保存表情的表,存储格式设计为utf8mb4,避免使用utf8。
  • 选择合适的数据类型。
  • 主外键字段类型一定要一致,否则会造成隐式转化,不走索引,造成生产事故!
  • 表以及字段上添加合理的注释。
  • 数据库表设计时,一定要在外键字段以及合适的字段上加索引。

 

上面是我数据库表设计时,遇到踩过坑以后的经验之谈。有些坑当时还真花了不少时间来填补。记录在这里,如果能帮助到你,那就太好了! 

责任编辑:庞桂玉 来源: 数据库开发
相关推荐

2024-04-01 08:05:27

Go开发Java

2017-07-17 15:46:20

Oracle并行机制

2015-03-24 16:29:55

默认线程池java

2024-05-06 00:00:00

缓存高并发数据

2023-03-13 13:36:00

Go扩容切片

2018-09-11 09:14:52

面试公司缺点

2018-01-10 06:17:24

2022-04-26 21:49:55

Spring事务数据库

2019-10-30 14:44:41

Prometheus开源监控系统

2019-12-12 14:32:26

SQL语句数据库

2019-02-19 09:46:58

美图容器化Kubernetes

2024-10-08 08:14:08

用户生命周期分析服务

2019-04-18 14:06:35

MySQL分库分表数据库

2018-08-01 14:45:16

PHP编程语言

2021-10-15 06:49:37

MySQL

2017-10-16 09:56:16

2019-09-25 15:30:15

2024-06-26 10:37:05

2020-11-03 13:50:31

Redis缓存数据库

2023-12-14 17:34:22

Kubernetes集群K8s
点赞
收藏

51CTO技术栈公众号