前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >MySQL数据类型选择性能比对

MySQL数据类型选择性能比对

作者头像
Leshami
发布于 2018-12-17 01:51:11
发布于 2018-12-17 01:51:11
69801
代码可运行
举报
文章被收录于专栏:乐沙弥的世界乐沙弥的世界
运行总次数:1
代码可运行

版权声明:本文为博主原创文章,欢迎扩散,扩散请务必注明出处。 https://blog.csdn.net/robinson_0612/article/details/84365551

关系型数据库建表期间,我们需要考虑很多很多的事项。诸如表存储什么数据,列上使用的数据类型,选择什么样的存储引擎等等。本文主要介绍针对表上列使用三种不同的数据类型来进行对比,以观察选择不同数据类型时,对于性能造成的影响。

一、建表时需要考虑的事项

作用:    存储什么数据? 结构:    包含什么列,需要约束吗? 存储:    每一列使用什么数据类型?需要索引吗? 引擎:    使用什么存储引擎呢? 数据筛选:    哪些列被频繁用作过滤条件?增删改查频率?

一、构造测试环境

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE TABLE `tb_char` (
  `uid` int(11) NOT NULL AUTO_INCREMENT,
  `mobile` char(11) DEFAULT NULL,
  `passwd` varchar(50) DEFAULT NULL,
  `name` varchar(50) DEFAULT NULL,
  `sex` tinyint DEFAULT NULL,
  `birthday` datetime DEFAULT NULL,
  `updated_time` datetime DEFAULT NULL,
  PRIMARY KEY (`uid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

使用三个表相同mobile列使用三种不同数据类型,分别为:
Char(11)
Varchar(11)
Bigint(11)

对应表名分别为:
tb_char
tb_varchar
tb_bigint
三张表总记录数100W,

测试环境:
(root@localhost) [tempdb]> show variables like 'version';
+---------------+------------+
| Variable_name | Value |
+---------------+------------+
| version | 5.7.23-log |
+---------------+------------+
select 'Leshami' author,'http://blog.csdn.net/leshami' Blog;
+---------+------------------------------+
| author | Blog |
+---------+------------------------------+
| Leshami | http://blog.csdn.net/leshami |
+---------+------------------------------+

二、基于无索引情形比对

表上统计信息,mysql统计信息不是很准确,如下图,基于bigint数据类型占用的磁盘你空间与char类型占用磁盘空间等同。varchar变长要大一些。因为varchar需要单独的字节来存放字符终止信息。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
-- 下面执行以下三条SQL语句比对性能
SELECT *
FROM tb_char
WHERE mobile = '17998335908';

SELECT *
FROM tb_varchar
WHERE mobile = '17998335908';

SELECT *
FROM tb_bigint
WHERE mobile = 17998335908;

每条SQL总计执行10次,观察每条好用的平均时间,bigint性能最佳。

二、基于索引情形比对

下面为过滤条件列mobile添加索引列,观察性能表现

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE INDEX uk_mobile  ON tb_char(mobile);
CREATE INDEX uk_mobile  ON tb_varchar(mobile);
CREATE INDEX uk_mobile  ON tb_bigint(mobile);

如下图所示,索引占用磁盘开销是bigint数据类型最小,基于索引查询的时间,三者相当

三、基于索引列分组聚合情形比对

为了更好比对性能,下面基于索引列进行分组以及聚合运算,可以看出依旧是bigint数据类型性能最佳

四、最终比对结果及结论

最终完整结果图:

结论: 1)满足需求的前提使用更小长度的数据类型(更少磁盘占用,I/O,CPU,memory开销) 2)整型优先原则,使用简单数据类型 3)避免使用NULL字段,NULL字段很难查询优化、的索引需要额外空间、复合索引无效 4)少用text/blob,varchar的性能会比text高很多

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018年11月23日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
MySQL数据类型选择性能比对详解
在关系型 数据库 建表期间,我们需要考虑很多很多的事项。诸如表存储什么数据,列上使用的数据类型,选择什么样的存储引擎等等。本文主要介绍针对表上列使用三种不同的数据类型来进行对比,以观察选择不同数据类型时,对于性能造成的影响。
星哥玩云
2022/08/17
6080
MySQL数据类型选择性能比对详解
MySQL数据类型 -- 字符型
版权声明:本文为博主原创文章,欢迎扩散,扩散请务必注明出处。 https://blog.csdn.net/robinson_0612/article/details/82824320
Leshami
2018/09/28
8680
MySQL数据类型 -- 字符型
MySQL(1)——数据类型的选择(一)
④. 结论:char 类型存储字符会剔除末尾的空格,而 varchar 存储会保留所有字符。
凡人飞
2020/09/18
1.2K0
MySQL数据类型 -- 数值型
版权声明:本文为博主原创文章,欢迎扩散,扩散请务必注明出处。 https://blog.csdn.net/robinson_0612/article/details/82823622
Leshami
2018/09/28
1.2K0
MySQL数据类型 -- 数值型
Mysql系列 - 第2天:详解mysql数据类型(重点)
上面表格中有符号和无符号写反了,[]包含的内容是可选的,默认是无符号类型的,无符号的需要在类型后面跟上unsigned
路人甲Java
2019/09/16
1.1K0
Mysql系列 - 第2天:详解mysql数据类型(重点)
mysql8数据类型详解
设计mysql表结构的时候,有很多数据类型供我们选择,下面来介绍下mysql8中常用的数据类型。
zhanyd
2022/05/16
2K0
mysql8数据类型详解
MySQL数据类型
总结: 如果插入的数据超过MySQL数据类型的范围,那么MySQL就不让你插入,直接拦截,不让做对应的操作。这点和C/C++一样,但是编译器不会报错,语言上给你发生截断,编译器内部可能会隐式转换。 如果已经有数据被成功插入到MySQL中,那么插入的时候一定是合法的。 因此,MySQL中,一般而言,数据类型本身也是一种约束。这种约束倒逼程序员,让程序员尽可能正确插入,如果不正确插入,MySQL也能保证插入的数据合法性。这样就能保证数据库中的数据是可预期完整的。
南桥
2024/07/26
1600
MySQL数据类型
MySQL(数据类型和完整约束)
default默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动添加默认值
全栈程序员站长
2022/07/21
1K0
mysql数据类型详解(1)
优化设计不良或索引不佳的架构能把性能提升几个数量级。如果需要高性能,就必须运行特定的查询设计架构和索引,还要评估不同类型查询的性能要求,因为更改某个查询或架构的一部分会对其他部分造成影响。例如,为了加快数据读取而添加的索引会减慢更新的速度。 选择优化的数据类型 遵循以下原则有助于更好的选择合适的数据类型 更小通常更好 更小的数据类型通常更快,因为他们使用更少的磁盘空间,内存和cpu缓存,而且需要的cpu周期更少 简单就好 越简单的数据类型,需要的cpu周期就越少。例如,比较整数的代价小于比较字符,因为字符集
wangxl
2018/03/08
9980
第12章_MySQL数据类型精讲
整数类型一共有 5 种,包括 TINYINT、SMALLINT、MEDIUMINT、INT(INTEGER)和 BIGINT。
程序员Leo
2023/08/07
4140
第12章_MySQL数据类型精讲
MySQL 的 JSON 数据类型,YYDS!
用过 MySQL 都知道,关系型的结构化存储存在一定的弊端,因为它需要预先定义好所有的列以及列对应的类型。但是业务在发展过程中,或许需要扩展单个列的描述功能,这时,如果能用好 JSON 数据类型,那就能打通关系型和非关系型数据的存储之间的界限,为业务提供更好的架构选择。
JavaFish
2022/03/15
2.4K0
MySQL从零开始:05 MySQL数据类型
距离上次更新 MySQL 从零开始系列,已经过去了十几天,时间隔得有点长,由于我选用的是 MySQL 的最新版本,网上的教程大多停留在 MySQL 5.x,所以要参阅一下官方文档,而文档是英文的,看起来比较耗时,希望大家可以理解,此系列一定会更新到底!
王强
2018/08/09
2.4K0
MySQL从零开始:05 MySQL数据类型
MySQL性能优化(二):选择优化的数据类型
良好的设计是高性能的基石,应该根据系统的实际业务需求、使用场景进行设计、优化、再调整,在这其中往往需要权衡各种因素,例如,数据库表究竟如何划分、字段如何选择合适的数据类型等等问题。
xcbeyond
2020/03/22
1.4K0
MySQL性能优化(二):选择优化的数据类型
MySQL数据类型 -- 日期时间型
版权声明:本文为博主原创文章,欢迎扩散,扩散请务必注明出处。 https://blog.csdn.net/robinson_0612/article/details/82824107
Leshami
2018/09/28
9810
MySQL数据类型 -- 日期时间型
MySQL数据类型与优化
1、假如只需要存0~255之间的数,无负数,应使用tinyint unsigned(保证最小数据类型) 2、如果长度不可定,如varchar,应该选择一个你认为不会超过范围的最小类型 比如: varchar(20),可以存20个中文、英文、符号,不要无脑使用varchar(150) 3、整形比字符操作代价更低。比如应该使用MySQL内建的类型(date/time/datetime)而不是字符串来存储日期和时间 4、应该使用整形存储IP地址,而不是字符串 5、尽量避免使用NULL,通常情况下最好指定列为NOT NULL,除非真的要存储NULL值 6、DATETIME和TIMESTAMP列都可以存储相同类型的数据:时间和日期,且精确到秒。然而TIMESTAMP只使用DATETIME一半的内存空间,并且会根据时区变化,具有特殊的自动更新能力。另一方面,TIMESTAMP允许的时间范围要小得多,有时候它的特殊能力会变成障碍
Java架构师必看
2021/05/14
1.7K0
高性能MySQL (一):Schema与数据类型优化
本文摘录总结自《高性能MySQL》(第三版),将以每章一篇文章的方式带大家读这本数据库经典之作。总结精华,帮大家快速抓住重点信息,节省宝贵时间。
solocoder
2022/04/06
1.1K0
结合案例说明MySQL的数据类型如何优化
看一个案例,下面是两张字段相同,字段类型相同,只是id字段emp1是smallint类型,emp2的id是bigint类型,分别向两个表插入5000条记录,观察一下表容量大小。
行百里er
2020/12/02
1.2K0
结合案例说明MySQL的数据类型如何优化
MySQL2_字符集及数据类型
文章目录 MySQL_字符集及数据类型 1.字符集 2.校对集 3.MySQL的数据类型--值的类型 (1)整型 (2)unsigned(无符号) (3)显示宽度(zerofill) (4)浮点型 (
以某
2023/03/07
4490
MySQL数据库,从入门到精通:第十二篇——MySQL数据类型详解
在MySQL数据库中,不同的数据类型决定了数据的存储方式和使用范围,选取合适的数据类型是合理设计数据库表的重要基础。本文将深入剖析MySQL的各种数据类型,包括整数类型、浮点类型、日期与时间类型、文本字符串类型、JSON类型等等,同时针对开发中的使用场景和技巧进行探讨,帮助读者更好地掌握MySQL中数据处理的技巧和方法。
默 语
2024/11/20
8250
MySQL数据库,从入门到精通:第十二篇——MySQL数据类型详解
第11章、数据类型
关键字 INT 是 INTEGER 的别名,关键字 DEC 和 FIXED 是 DECIMAL的别名。 在 MyISAM/MEMORY/InnoDB和NDB表中支持BIT 数据类型,BIT 数据类型用于存储 bit 值。
幺鹿
2018/08/21
1.8K0
第11章、数据类型
相关推荐
MySQL数据类型选择性能比对详解
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验