当前位置:首页 > 文章列表 > 数据库 > MySQL > MySQL数据类型选择

MySQL数据类型选择

来源:SegmentFault 2023-02-25 10:11:03 0浏览 收藏

对于一个数据库开发者来说,牢固扎实的基础是十分重要的,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类型是合适的:

  1. 字符串的最大长度比平均长度大很多

  2. 列的更新很少。这是因为行是变长的,在update时可能使行变的比原来更长。如果行占用的空间增长,并且在页内没有更多的空间可以存储,就需要存储引擎特别的处理。例如,Innodb存储引擎需要分裂页使行放入页内。这会导致增加内存碎片,降低数据库性能。

char类型是定长的。它的最大宽度为255。
char类型字符串末尾的空格会被删除。
下面的这些情况使用char类型是合适的:

  1. 存储很短的字符串,或者所有字符串长度都比较接近。短字符串用char类型存储比用varchar类型效率要高。

  2. 经常变更的数据。因为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类型的值会有变化。

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列赋当前时间值

可以从例子中看到,MySql会自动给timestamp类型的列用当前时间赋值。而datetime类型的列不会。

timestamp类型列会自动更新成当前时间

当更新列时,timestamp类型的列也会自动更新成当前时间。

标识列的类型选择

标识列可能会和其它值进行比较(如在关联操作中),或者根据标识列寻找其它列。标识列也可能作为其它表的外键使用。所以为标识列选择恰当的数据类型非常重要。
整数类型是标识列最好的选择,因为整数计算很快并且可以AUTO_INCREMENT。
应该尽可能避免采用字符串类型作为标识列。因为字符串类型很消耗空间,并且计算比数字类型要慢。

好了,本文到此结束,带大家了解了《MySQL数据类型选择》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!

版本声明
本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
【MySQL笔记】七种JOIN的SQL【MySQL笔记】七种JOIN的SQL
上一篇
【MySQL笔记】七种JOIN的SQL
最优方案实现同步数据至HUBSPOT
下一篇
最优方案实现同步数据至HUBSPOT
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    514次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    499次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • SEO  AI Mermaid 流程图:自然语言生成,文本驱动可视化创作
    AI Mermaid流程图
    SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
    633次使用
  • 搜获客笔记生成器:小红书医美爆款内容AI创作神器
    搜获客【笔记生成器】
    搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
    640次使用
  • iTerms:一站式法律AI工作台,智能合同审查起草与法律问答专家
    iTerms
    iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
    655次使用
  • TokenPony:AI大模型API聚合平台,一站式接入,高效稳定高性价比
    TokenPony
    TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
    724次使用
  • 迅捷AIPPT:AI智能PPT生成器,高效制作专业演示文稿
    迅捷AIPPT
    迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
    619次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码