MySQL数据类型选择
来源:SegmentFault
时间:2023-02-25 10:11:03 493浏览 收藏
对于一个数据库开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《MySQL数据类型选择》,主要介绍了MySQL,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!
当一个列可以选择多种数据类型时,应该优先选择数字类型,其次是日期或二进制类型,最后是字符类型。越简单的数据类型,需要的处理资源就越少。
对于相同级别的数据类型,应该优先选择占用空间小的数据类型。因为在数据库中,数据处理是以页为单位的,每个页存储的数据量是一定的(Innodb一页是16K),列的长度越小,单页能容纳的行数就越多。这有利于减少磁盘IO,提高数据库性能。
最好指定列为NOT NULL。可为NULL的列对MySQL来说很难优化,因为可为NULL的列使得索引、索引统计和值比较都更复杂。可为NULL的列也会占用更多的存储空间。
整数类型
注意,MySql虽然可以为整数指定宽度,例如int(11),但是这没有任何意义,它并不会限制值的合法范围
实数类型
可以利用DECIMAL存储比BIGINT还大的整数。
CPU不支持对DECIMAL的直接计算,是MySQL自身实现了对DECIMAL的高精度计算。MySQL将DECIMAL类型的数字用二进制字符串存储,每4个字节存9个数字。例如,DECIMAL(18,9)小数点两边各存储9个数字,所以小数点两边各占用4个字节,再加上小数点本身占用1个字节,总共占用9个字节。DECIMAL类型的计算效率没有DOUBLE和FLOAT高。
MySQL使用DOUBLE作为内部浮点计算类型。
因为DECIMAL类型需要比较大的空间和计算开销,所以应该只在对小数进行精确计算时才使用DECIMAL。
VARCHAR和CHAR类型
varchar类型用于存储可变长字符串,它只占用必要的存储空间。
varchar需要使用1或2个额外字节记录字符串的长度:如果字符串的最大长度小于255则只占用1个字节用于记录字符串长度,如果字符串的长度大于255则要占用2个字节用于记录字符串的长度。这就代表varchar的最大长度就是65535。但是在实际中varchar列不能达到65535这么大,因为对innodb来说,65535是一行中所有varchar列共享的长度。
下面的这些情况使用varchar类型是合适的:
字符串的最大长度比平均长度大很多
列的更新很少。这是因为行是变长的,在update时可能使行变的比原来更长。如果行占用的空间增长,并且在页内没有更多的空间可以存储,就需要存储引擎特别的处理。例如,Innodb存储引擎需要分裂页使行放入页内。这会导致增加内存碎片,降低数据库性能。
char类型是定长的。它的最大宽度为255。
char类型字符串末尾的空格会被删除。
下面的这些情况使用char类型是合适的:
存储很短的字符串,或者所有字符串长度都比较接近。短字符串用char类型存储比用varchar类型效率要高。
经常变更的数据。因为char类型是定长的,对其变更不会产生内存碎片。
varchar和char的宽度都是以字符为单位的。两种类型相比,char类型会去掉字符串末尾的空格,而varchar类型不会。
VARCHAR(5)和VARCHAR(20)存储hello的空间开销是一样的,那么使用更短的列有什么优势吗?
有很大的优势。MySql通常会分配固定大小的内存块存储内部值。虽然varchar类型在磁盘上是采用变长的方式存储,但在内存中存储varchar类型字符串使用的是其最大宽度。所以更长的列会消耗更大的内存。应该只分配真正需要的空间。
日期和时间类型
MySql能存储的最小时间粒度为秒,但是MySql可以使用微妙级别的粒度进行临时运算。
DATETIME类型:
DATETIME可以保存从1001年到9999年之间的时间值,精度为秒,占用8个字节的存储空间。它将时间值保存到格式为YYYYMMDDHHMMSS的整数中,保存的时间值与时区无关。
TIMESTAMP类型:
TIMESTAMP就是时间戳,它保存了从1970年1月1日零点以来的秒数,与UNIX时间戳值相同。TIMESTAMP只占用4个字节的存储空间,表示的时间范围只能从1970年到2038年。
TIMESTAMP显示的值依赖于时区,下面例子展示了在不同的时区下TIMESTAMP类型的值会有变化。
创建的test_date表分别包含了timestamp类型的列和datatime类型的列。通过set time_zone='+10:00'命令设置时区。向表中插入一行记录,两个列的值都是当前时间。通过select语句查看结果,两种不同类型列的值是相同的。再通过set time_zone='-10:00'命令修改时区,从第二次select语句的执行结果可以看到,timestamp类型列的值已经改变了,而datetime类型列的值没有改变。
timestamp还有datetime没有的特殊属性,默认情况下,如果insert时没有指定第一个timestamp类型列的值时,MySql会自动设置这个列的值为当前时间。在更新一行记录时,MySql也会自动更新timestamp类型列的值。
可以从例子中看到,MySql会自动给timestamp类型的列用当前时间赋值。而datetime类型的列不会。
当更新列时,timestamp类型的列也会自动更新成当前时间。
标识列的类型选择
标识列可能会和其它值进行比较(如在关联操作中),或者根据标识列寻找其它列。标识列也可能作为其它表的外键使用。所以为标识列选择恰当的数据类型非常重要。
整数类型是标识列最好的选择,因为整数计算很快并且可以AUTO_INCREMENT。
应该尽可能避免采用字符串类型作为标识列。因为字符串类型很消耗空间,并且计算比数字类型要慢。
好了,本文到此结束,带大家了解了《MySQL数据类型选择》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
-
452 收藏
-
283 收藏
-
141 收藏
-
186 收藏
-
138 收藏
-
457 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习