MySQL数据类型选择性能比对

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

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

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

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

一、构造测试环境

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需要单独的字节来存放字符终止信息。

-- 下面执行以下三条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添加索引列,观察性能表现

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高很多

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏大闲人柴毛毛

数据库索引全面解析

索引是什么? 数据库中查找操作非常普遍,索引就是提升查找速度的一种手段。 索引分类 B+树索引 它就是传统意义上的索引,它是最常用、最有效的索引。 哈希索...

3566
来自专栏别先生

MySql的基本操作以及以后开发经常使用的常用指令

第一章:数据类型和操作数据表 MySQL语句的规范 (1):关键字与函数名称全部大写 (2):数据库名称,表名称,字段名称全部小写 (3):SQL语句必须以分号...

19110
来自专栏MYSQL轻松学

MySQL replace用法简介

今天在工作的过程中碰到一个问题,要把数据库中某个列的所有值中含有"ceshi.test.com"的字符去掉,本来可以写个脚本,把所有的值都取出再导入进行处理,但...

3839
来自专栏Jackson0714

聚集索引VS非聚集索引

2986
来自专栏后端技术探索

MySQL中的两种临时表 外部临时表

通过CREATE TEMPORARY TABLE 创建的临时表,这种临时表称为外部临时表。这种临时表只对当前用户可见,当前会话结束的时候,该临时表会自动关闭。这...

790
来自专栏MySQL内核

MySQL InnoDB创建索引

InnoDB的索引基于B+树实现,每张InnoDB的表都有一个特殊的索引,叫做聚簇索引(Clustered Index),聚簇索引存储了表中的真实数据。索引项的...

3472
来自专栏十月梦想

mysql基础操作实例

之前写过一篇mysql基础指令集合,感觉看指令在一些新手朋友来说有点不爽很容易理解,正好现在自己开始自学mysq就把这里基础的指令使用代码展示一下,希望能帮...

1043
来自专栏兵马勇的专栏

sparksql 中外连接查询中的谓词下推处理

上月听了本部门 sparksqll 大牛的 sparksql 调优分享,当时对一个点不是很理解,回去好好理了一下,整理成文。

7841
来自专栏Hongten

python开发_python操作mysql数据库

如果你还没有准备好开发环境,你不妨花上一小点时间去看看:python开发_mysqldb安装

1043
来自专栏资深Tester

SQL系列之DDL/DCL语言

2456

扫码关注云+社区

领取腾讯云代金券