偶然的机会,得知mysql主键的类型采用 varchar 存UUID 的查询性能没有int型做主键好。网上查询大量资料,都是停留在理论上的,因此,自己写了代码进行实测,以下结果仅供参考,不具备权威性。

三个表的字段,除了主键ID 分别采用varchar,bigint 和自动增长bigint不同外,其他三个字段都为 varchar 36位

数据库:mysql5.5

表类型:InnoDB

数据量:100W条

第一种情况:

主键采用uuid 32位。

运行查询语句1:SELECT COUNT(id) FROM test_varchar;

运行查询语句2:SELECT * FROM test_varchar WHERE vname=’00004629-b052-11e1-96aa-002655b28d7b’;

运行查询语句3:SELECT * FROM test_varchar WHERE id=’00004599b05211e196aa002655b28d7b’;

语句1消耗时间平均为:2.7秒;

语句2消耗时间平均为:3秒;

语句3消耗时间平均为:0秒;(多方测试,条件里只要有主键ID,查询速度毫秒级都显示000。测试的ID值,有前一百条的,也有后90多万条的。查询时间完全一样,毫秒级都为000)

第二种情况:

主键采用bigint,使用uuid_short()产生数据,数据为有序列的纯数字(22461015967875697)。(其相当于自动增长,只是固定的基数值较大而已。)

运行查询语句1:SELECT COUNT(id) FROM test_long;

运行查询语句2:SELECT * FROM test_long WHERE vname=’d7f28a24-b053-11e1-96aa-002655b28d7b’;

运行查询语句3:SELECT * FROM test_long WHERE id=’22461015967875702′;

语句1消耗时间平均为:1.2秒;

语句2消耗时间平均为:1.40秒;

语句3消耗时间平均为:0秒;(多方测试,条件里只要有主键ID,查询速度毫秒级都显示000。测试的ID值,有前一百条的,也有后90多万条的。查询时间完全一样,毫秒级都为000)

第三种情况:

运行查询语句1:SELECT COUNT(id) FROM test_int;

运行查询语句2:SELECT * FROM test_int WHERE vname=’c80f8427-b059-11e1-96aa-002655b28d7b’;

运行查询语句3:SELECT * FROM test_int WHERE id=900000;

主键采用mysql自带的自动增长,数据为纯数字(1,2,3,4,5……)。

查询语句1消耗时间平均为:1.07秒;

查询语句2消耗时间平均为:1.31秒;

查询语句3消耗时间平均为:0秒;(多方测试,条件里只要有主键ID,查询速度毫秒级都显示000。测试的ID值,有前一百条的,也有后90多万条的。查询时间完全一样,毫秒级都为000)

总结:由此可见,mysql InnoDB 主键采用自动增长性能较高。

笔者自语:平时的项目开发,sql语句的条件里有ID的,占多数,没有的占少数。虽然以上的测试表明只要条件语句里有主键ID,主键类型不一样,查询时间完全一样。但是,你不能保证你的项目中所有sql语句的条件里都有ID,因此…………主键的类型该采用哪种,相信各位看官已经明白。

———————————————————华丽的分割线———————————————————-

数据库:mysql5.5

表类型:MyISAM

数据量:100W条

为了少写一些字,节省时间,此测试所使用的表和sql语句同上,此处只记录消耗时间。

第一种情况:

主键采用uuid 32位。

语句1消耗时间平均为:0秒;

语句2消耗时间平均为:0.53秒;

语句3消耗时间平均为:0秒;(多方测试,条件里只要有主键ID,查询速度毫秒级都显示000。测试的ID值,有前一百条的,也有后90多万条的。查询时间完全一样,毫秒级都为000)

第二种情况:

主键采用bigint,使用uuid_short()产生数据,数据为有序列的纯数字(22461015967875697)。(其相当于自动增长,只是固定的基数值较大而已。)

语句1消耗时间平均为:0秒;

语句2消耗时间平均为:0.51秒;

语句3消耗时间平均为:0秒;(多方测试,条件里只要有主键ID,查询速度毫秒级都显示000。测试的ID值,有前一百条的,也有后90多万条的。查询时间完全一样,毫秒级都为000)

第三种情况:

主键采用mysql自带的自动增长,数据为纯数字(1,2,3,4,5……)。

语句1消耗时间平均为:0秒;

语句2消耗时间平均为:0.48秒;

语句3消耗时间平均为:0秒;(多方测试,条件里只要有主键ID,查询速度毫秒级都显示000。测试的ID值,有前一百条的,也有后90多万条的。查询时间完全一样,毫秒级都为000)

总结:由此可见,mysql MyISAM 主键采用自动增长性能比其他有微弱的优势。测试数据为100w,如果是1000W 1亿,我想这个优势会拉大,如果你还有外键关联查询,这个优势就更明显了。当然,如果你设计的系统,数据量还没有超过100W,你用啥主键类型都无所谓。我测试电脑是笔记本,如果是专业的服务器,估计100W条,mysql MyISAM 的这些测试,根本都测不出来时间差。

大总结:本来是要测mysql主键类型不同,查询效率的差别的,怎么写到最后,感觉像是在测mysql InnoDB和MyISAM的优劣了,无限纠结中……,有时间测下oracle!!

来源:http://j2ees.iteye.com/blog/1554423

mysql int做主键_mysql5.5 uuid做主键与int做主键的性能实测相关推荐

  1. 数据库主键到底是用自增长(INT)好还是UUID好?

    数据库主键到底是用自增长(INT)好还是UUID好? 使用自增长做主键的优点: 1.很小的数据存储空间 2.性能最好 3.容易记忆 使用自增长做主键的缺点: 1.如果存在大量的数据,可能会超出自增长的 ...

  2. mysql支持UUID做外键_多表外键下将普通的id主键更新为uuid主键

    多表外键下将普通的id主键更新为uuid主键 2019-05-20 02:45:37 来源: 晴天小雨 0 摘要:在多表外键影响和保证数据不删除的前提下,借助Flask-sqlalchemy插件及SQ ...

  3. easycode不推荐使用_为什么MySQL不推荐使用uuid或者雪花id作为主键?

    注:本文讨论范围限于两者都适用的前提下,为什么优先推荐使用连续自增的主键id,uuid或者雪花id有其不可替代的场景,暂不做讨论 前言 在mysql中设计表的时候,mysql官方推荐不要使用uuid或 ...

  4. mysql添加外键的时候报错_mysql处理添加外键时 error 150 问题

    当你试图在mysql中创建一个外键的时候,这个出错会经常发生,这是非常令人沮丧的.像这种不能创建一个.frm 文件的报错好像暗示着操作系统的文件的权限错误或者其它原因,但实际上,这些都不是的,事实上, ...

  5. MySQL记录删除后竟能按中间被删除的主键加回去,磁盘空间被重用!——底层揭秘MySQL行格式记录头信息

    说在前面--本篇也是我读书总结笔记,因为是讲底层原理,我个人认为本文难度是相当高的,可能需要一定的基础. 我将文中的图片包含的计算原理全都演算了一遍,因为书本没有过程详细计算,欢迎大家阅读和仔细推敲. ...

  6. MySQL记录删除后竟能按中间被删除的主键加回去,磁盘空间被重用!

    说在前面--本篇也是我读书总结笔记,因为是讲底层原理,我个人认为本文难度是相当高的,可能需要一定的基础. 我将文中的图片包含的计算原理全都演算了一遍,因为书本没有过程详细计算,欢迎大家阅读和仔细推敲. ...

  7. MySQL【四】---案例实战{拆分多表、外键创建等}

    1.准备数据 数据准备 create database jing_dong charset = utf8mb4; 创建一个商品goods数据表: create table goods( id int ...

  8. mysql数据库怎么添加主键约束_mysql修改表时怎么添加主键约束?

    mysql中可以通过"ALTER TABLE 表名 ADD PRIMARY KEY(字段名);"语句在修改数据表时添加主键约束:当在修改表时要设置表中某个字段的主键约束时,要确保设 ...

  9. Mysql 索引(三)—— 不同索引的创建方式(主键索引、普通索引、唯一键索引)

    了解了主键索引的底层原理,主键索引其实就是根据主键字段建立相关的数据结构(B+树),此后在使用主键字段作为条件查询时,会直接根据主键查找B+树的叶子结点.除了主键索引外,普通索引和唯一键索引也是如此, ...

最新文章

  1. log parser 微软iis 日志分析
  2. OGEngine开源引擎环境搭建
  3. vue main.js 导入文件报错Module build failed: Error: No PostCSS Config found in:
  4. vs 属性 环境变量
  5. 如何在eclipse中安装git?
  6. RHEL7 - 从命令行管理文件
  7. 不会发布npm包?进来看看?
  8. 10蓝牙_小米10手机专用?小米“真无线蓝牙耳机Air 2s”评测
  9. VB 源码 产生任意数之间随机数,支持负数
  10. codeblocks 汉化
  11. 记住这36条创业军规
  12. electron 调试、问题追踪
  13. 有关H5的第三章表单介绍
  14. esxi服务器更换硬盘,ESXi下磁盘分区删除步骤详解
  15. Python 之 列表推导式
  16. 重复制造 成本收集器 月结 Period-end closing Product cost collector
  17. 激光投影虚拟键盘的设计与实现
  18. 我们如何使用Firestore和Firetable构建虚拟实时事件平台
  19. TWRP Recovery 编译适配教程
  20. Data Wrangling数据处理

热门文章

  1. rc.local自启动学习
  2. 【参数】REMOTE_LOGIN_PASSWORDFILE参数三种取值及其行为特性分析
  3. Reveal使用心法
  4. 测试C#代码执行时间
  5. 在线网站原型设计工具Cacoo
  6. 【iOS-Cocos2d游戏开发之十一】使用Box2d物理系统以及在cocos2d框架添加Box2d物理系统lib包的方法...
  7. 如何在单台计算机上配置 Windows XP SP2 网络保护技术
  8. ruby html解析器
  9. chengren-成人-php系列3
  10. Boson NetSim实验模拟器破解