这篇文章主要讲解了“建表为什么还设置个自增 id”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“建表为什么还设置个自增 id”吧!1.建表规约在工作中,创建表
这篇文章主要讲解了“建表为什么还设置个自增 id”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“建表为什么还设置个自增 id”吧!
1.建表规约
在工作中,创建表的时候,DBA 也会审核一下建表 sql,检查是否符合规范以及常用字段是否设置索引。
CREATE TABLE `xxxx` ( `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '自增主键', `create_time` datetime(3) NOT NULL DEFAULT current_timestamp(3) COMMENT '创建时间', `update_time` datetime(3) NOT NULL DEFAULT current_timestamp(3) ON UPDATE current_timestamp(3) COMMENT '更新时间', PRIMARY KEY (`id`) USING BTREE, KEY `idx_create_time` (`create_time`) USING BTREE, KEY `idx_update_time` (`update_time`) USING BTREE ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4 COMMENT='表注释';
所以在我使用的过程中,流水号都是单独设置了一个字段,比如叫 trans_no,但是这次就遇到了疑问:trans_no 既然是唯一的,那为什么不直接用 trans_no 当做 id 呢?
下面开始通过查阅相关资料,一步一步的了解是为什么?
2.主键
什么是主键?
Mysql primary key
这段定义咱们主要关注最后一句:
" When choosing primary key values, consider using arbitrary values (a synthetic key) rather than relying on values derived from some other source (a natural key). "
意思是创建主键的时候尽量使用 mysql 自增主键而不是使用业务生成的值当做主键。
主键的特征
简而言之:
非空、唯一、少更改或不更改 。
如何添加主键
可以在 create 创建表的时候指定,也可以使用 alter 语句后面添加主键,不过官方建议在创建表时就指定。
为什么要添加主键
主键可以唯一标识这一行数据,从而保证在删除更新操作时,只是操作这一行数据。
索引需要,每个 InnoDB 表又有一个特殊的索引,即聚簇索引,用来存储行数据。通常,聚簇索引和主键同义。
声明主键,InnoDB 会将主键作为聚簇索引。
未声明时,会在 UNIQUE 所有键列所在位置找到第一个索引,NOT NULL 并将其作为聚簇索引
未声明且找不到合适的 UNIQUE 索引,则内部生成一个隐藏的聚簇索引 GEN_CLUST_INDEX,这个隐藏的行 ID 是 6 字节且单调增加。
3.索引
这里仅介绍 InnoDB 引擎,具体可以参考官方文档,并且介绍的相对比较简单。
索引的分类
聚簇索引:表存储是根据主键列的值组织的,以加快涉及主键列的查询和排序。在介绍主键时也对聚簇索引进行了介绍。
二级索引:也可以叫辅助索引,在辅助索引中会记录对应的主键列以及辅助索引列。根据辅助索引进行搜索的时候,会先根据辅助索引获取到对应的主键列,然后再根据主键去聚簇索引里面搜索。一般不建议主键很长,因为主键很长辅助索引就会使用更多的空间。
" 补充:
回表:先在二级索引查询到对应的主键值,然后根据主键再去聚簇索引里面取查询。
索引覆盖:二级索引记录了主键列和二级索引列,如果我只查询主键列的值和二级索引列的值,那就不需要回表了。 "
索引的物理结构
InnoDB 使用的 B+ 数数据结构,根据聚簇索引值(主键/UNQIUE/或者自己生成)构建一颗 B+ 树,叶子节点中存放行记录数据,所以每个叶子节点也可以叫数据页。每个数据页大小默认为 16k,支持自定义。
数据的插入
当数据插入时,InnoDB 会使页面 1/16 空闲,以备将来插入和更新索引记录。
顺序插入(升序或降序):会将索引页剩余的大约 15/16 装满
随机插入:只会使用容量的 1/2 到 15/16
在随机插入中,会频繁的移动、分页,从而造成大量的碎片,并且使索引树不够紧凑。而使用顺序插入的方式,则数据比较紧凑,有更高的空间利用率。
4.总结
Q&A
Q: 什么是回表和索引覆盖?
A:
回表:先在二级索引查询到对应的主键值,然后根据主键再去聚簇索引里面取查询。
索引覆盖:二级索引记录了主键列和二级索引列,如果我只查询主键列的值和二级索引列的值,那就不需要回表了。
Q: 为什么要设置自增主键 id ?
A:
可以唯一标识一行数据,在 InnoDB 构建索引树的时候会使用主键。
自增 id 是顺序的,可以保证索引树上的数据比较紧凑,有更高的空间利用率以及减少数据页的分裂合并等操作,提高效率。
一般使用手机号、身份证号作为主键等并不能保证顺序性。
流水号一般相对较长,比如 28 位,32 位等,过长的话会二级索引占用空间较多。同时为了业务需求,流水号具有一定的随机性。
感谢各位的阅读,以上就是“建表为什么还设置个自增 id”的内容了,经过本文的学习后,相信大家对建表为什么还设置个自增 id这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!
--结束END--
本文标题: 建表为什么还设置个自增 id
本文链接: https://lsjlt.com/news/61999.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0