回答星球水友提问:沈老师,我听网上说,MySQL数据表,在数据量比较大的情况下,主键不宜过长,是不是这样呢?这又是为什么呢?

这个问题嘛,不能一概而论:

(1)如果是InnoDB存储引擎,主键不宜过长;

(2)如果是MyISAM存储引擎,影响不大; 先举个简单的栗子说明一下前序知识。 假设有数据表:

t(id PK, name KEY, sex, flag); 其中:(1)id是主键;(2)name建了普通索引; 假设表中有四条记录:

1, shenjian, m, A

3, zhangsan, m, A

5, lisi, m, A

9, wangwu, f, B 如果存储引擎是MyISAM,其索引与记录的结构是这样的:

(1)有单独的区域存储记录(record);

(2)主键索引与普通索引结构相同,都存储记录的指针(暂且理解为指针);

画外音:

(1)主键索引与记录不存储在一起,因此它是非聚集索引(Unclustered Index);

(2)MyISAM可以没有PK; MyISAM使用索引进行检索时,会先从索引树定位到记录指针,再通过记录指针定位到具体的记录。

画外音:不管主键索引,还普通索引,过程相同。InnoDB则不同,其索引与记录的结构是这样的:

(1)主键索引与记录存储在一起;

(2)普通索引存储主键(这下不是指针了);

画外音:

(1)主键索引与记录存储在一起,所以才叫聚集索引(Clustered Index);

(2)InnoDB一定会有聚集索引; InnoDB通过主键索引查询时,能够直接定位到行记录。

但如果通过普通索引查询时,会先查询出主键,再从主键索引上二次遍历索引树。

回归正题,为什么InnoDB的主键不宜过长呢?

假设有一个用户中心场景,包含身份证号,身份证MD5,姓名,出生年月等业务属性,这些属性上均有查询需求。

最容易想到的设计方式是:

身份证作为主键

其他属性上建立索引

user(id_code PK,

id_md5(index),

name(index),

birthday(index));

此时的索引树与行记录结构如上:

id_code聚集索引,关联行记录

其他索引,存储id_code属性值

身份证号id_code是一个比较长的字符串,每个索引都存储这个值,在数据量大,内存珍贵的情况下,MySQL有限的缓冲区,存储的索引与数据会减少,磁盘IO的概率会增加。画外音:同时,索引占用的磁盘空间也会增加。 此时,应该新增一个无业务含义的id自增列:

以id自增列为聚集索引,关联行记录

其他索引,存储id值

user(id PK auto inc,

id_code(index),

id_md5(index),

name(index),

birthday(index));

如此一来,有限的缓冲区,能够缓冲更多的索引与行数据,磁盘IO的频率会降低,整体性能会增加。 总结(1)MyISAM的索引与数据分开存储,索引叶子存储指针,主键索引与普通索引无太大区别;(2)InnoDB的聚集索引和数据行统一存储,聚集索引存储数据行本身,普通索引存储主键;(3)InnoDB不建议使用太长字段作为PK(此时可以加入一个自增键PK),MyISAM则无所谓;

希望解答了这位水友的疑问。

本文由 58沈剑 发布在 ITPUB,转载此文请保持文章完整性,并请附上文章来源(ITPUB)及本页链接。

原文链接:http://www.itpub.net/2019/10/02/3310/

mysql 主键长度_MySQL 数据库,主键为何不宜太长长长长长长长长?相关推荐

  1. mysql修改级联表数据_MySQL数据库 外键,级联, 修改表的操作

    1.外键: 用来建立两张表之间的关系 - 一对多 - 多对多 - 一对一 研究表与表之间的关系: 1.定义一张 员工部门表 id, name, gender, dep_name, dep_desc - ...

  2. mysql 从库_mysql数据库主从配置

    在一篇文章<离线安装mysql数据库>,讲解了离线安装mysql数据库的过程,本文将讲解mysql数据库的主从配置方法.mysql数据库进行主从配置后,可以实现数据库的备份.同时应用也可以 ...

  3. mysql case默认_MySQL数据库架构和同步复制流程

    在分布式系统里面,往往制约整个系统发展的瓶颈点就是数据库,所以数据库的架构和高可用以及数据库的切分都是我们值得花大力气去学习的. 首先我们来说说数据库的架构. 1.mysql主从架构,如图: 这种架构 ...

  4. amoeba mysql读写分离_mysql数据库-基于amoeba读写分离

    环境: 主机A( huangzp2):172.16.115.157 主机B( huangzp3):172.16.115.100 主机C( huangzp4):172.16.115.87 说明: 依赖于 ...

  5. mysql权限表_MySQL 数据库赋予用户权限操作表

    MySQL清空数据库的操作:truncate table tablename; MySQL 赋予用户权限命令的简单格式可概括为:grant 权限 on 数据库对象 to 用户 一.grant 普通数据 ...

  6. mysql删除原则_MySQL数据库的增删选查

    数据库是专门存储数据对象的容器,这里的数据对象包括表.视图.触发器.存储过程等,其中表是最基本的数据对象. 创建数据库 在 MySQL 数据库中存储数据对象之前,先要创建好数据库. 语法: creat ...

  7. mysql select表达式_MySQL数据库SELECT查询表达式解析

    数据的管理在很大一部分是在进行查找工作,而SELECT占据了很大的一部分 SELECT select_expr [,select_expr...] [ FROM table_reference WHE ...

  8. mysql断网_mysql数据库断网链接

    {"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],&q ...

  9. centos72安装mysql配置密码_MySQL数据库之170419、Centos7下完美安装并配置mysql5.6

    本文主要向大家介绍了MySQL数据库之170419.Centos7下完美安装并配置mysql5.6 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助. linxu环境: centos ...

最新文章

  1. 网络营销推广软件浅析外链怎么做才更“香”,才能促进网站自然有首页排名?...
  2. docker-engine安装好了,下一步该做什么?
  3. 在eclipse中安装properties插件PropertiesEditor及设置(附图),ASCII码转换成中文
  4. SAP Spartacus由于导入module路径在服务器上不正确而导致的Travis build错误
  5. git 应用 创建分支 并切换分支
  6. Spring学习总结(29)——Spring异步处理@Async的使用以及原理、源码分析(@EnableAsync)
  7. uva 540 (Team Queue UVA - 540)
  8. Matlab自带的曲线拟合程序
  9. BlackBone工具集合:注入、hook、驱动程序
  10. Java IO流笔记4 --- File类
  11. 【岗位技能要求】人工智能+Python
  12. 实训-利用HTML和CSS制作一个网页界面
  13. 什么是涡以及vortex和eddy的区别
  14. 《老子》古本学习札记
  15. linux R语言 安装
  16. 读书笔记三:《运营之光》互联网运营方法论与自白(上)
  17. 解决npm一直停在“checking installable status“的问题
  18. 从招聘网站看程序员的分工
  19. 成功解决:双击eclispe安装文件后没反应
  20. android 图片排版,Android版美图秀秀优化拼图排版

热门文章

  1. php数组转换编码,PHP数组转换编码类
  2. jssdk分享设置_JSSDK自定义分享
  3. wps临时文件不自动删除_电脑:让 Windows 10 系统自动清理临时文件
  4. pwm控制的基本原理_单片机PWM控制基本原理详解~
  5. 逐行对比两个文件内容的好用软件
  6. matlab中GUIDE的UItable居中方法
  7. SIFT算法中概念简单解释
  8. Fater R-CNN 整体把握
  9. 这个C怎么了?求大佬指教
  10. Grafana 使用教程 --- 开源的度量分析与可视化套件