我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL 数据类型及最优选取规则

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL 数据类型及最优选取规则

数据类型

日常开发中,最常使用到的 MySQL 中常用的数据类型有 : 整型, 浮点型, 定点数, 字符型, 时间日期类型. 下面对其分别进行总结。

整型

格式为 : INT[(M)] [UNSIGNED] [ZEROFILL]

  • 取值范围:如果是 unsigned 无符号位 , 则最大值翻倍, 如 tinyint unsigned 的取值范围为 (0~256).
  • 注意:INT(1) 和 INT(10) 没有区别, 占用的内存都一样, 并不是代表其最大位数,只是加上 (M) 值后, 在 CMD 中显示的结果的宽度不同而已. 只有在加上 zerofill 零填充后 M 才表现出有点点效果, 比如 int(3) zerofill, 插入到数据库里的是 10, 则实际插入为 010, 也就是在前面补充加了一个0.
  • Java 中的 Long 类型, 和 MySQL 中的 bigint 相对应.
  • Java 中的 Integer 类型, 和 MySQL 中的 int 相对应.
  • Java 中的 Boolean 类型, 和 MySQL 中的 tinyint 相对应.  false 代表 0, true 代表 1.

浮点型

  • 设一个字段定义为 float(5,3), 5 表示在 CMD 中显示的总位数是 5 位, 3 表示小数位是 3 位.
  • 小数位超过指定长度, 对后面的数字按照四舍五入截取. 所以如果插入一个数 123.45678, 实际数据库里存的是123.457, 进行了四舍五入截取.
  • 小数位如果都是0, 则不保存小数位, 直接保存整数.

定点数

浮点型在数据库中存放的是近似值, 而定点类型在数据库中存放的是精确值. 所以对于金额等精度要求高的数据, 使用定点数 decimal 来保存.

decimal(m,d) 参数 m 是总个数, d 是小数位.  ( m<65, d<30, d<m )

字符型

字符型含义占用字节数
char(n)固定长度, 最多 255 个字符4 byte
varchar(n)可变长度, 最多 65535 个字符实际存入字节数+1
  • char 类型的字符串检索速度要比 varchar 类型的快. 所以能 char 的优先 选择 char.
  • char(n) 若存入字符数小于 n, 则以空格补于其后, 查询之时再将空格去掉. 所以 char 类型存储的字符串末尾不能有空格, varchar 不限于此.
  • char(n) 固定长度, char(4) 不管是存入几个字符, 都将占用 4 个字节. varchar 可变长度, 是存入的实际字符数+1个字节(n<=255)或 2 个字节(n>255),  所以 varchar(4), 存入3 个字符将占用 4 个字节.
  • varchar(10) 的 10 代表了申请的空间长度, 即存储的数据的最大长度, 而 int(10) 的 10 只是代表了展示的长度.

日期时间型

日期时间类型占用空间(字节数)日期格式
DATETIME8 byteYYYY-MM-DD HH:MM:SS
TIMESTAMP4 byteYYYY-MM-DD HH:MM:SS
DATE4 byteYYYY-MM-DD
TIME3 byteHH:MM:SS
YEAR1 byteYYYY
  • 根据实际需要选择能够满足的最小存储的类型即可. 比如 : DATE 用于表示 年月日, 生日字段使用 DATE 类型即可. 这样不但能节省内存, 还能提高表的操作效率.
  • 如果要记录年月日时分秒, 而且记录的年代比较久远, 最好使用 DATETIME. 因为 TIMESTAMP 可以表示的年代范围比 DATETIME 少的多.
  • 如果记录的日期需要用到时区, 需要选择 TIMESTAMP.
  • 一个表中至多只能有一个字段设置 CURRENT_TIMESTAMP. 并且 CURRENT_TIMESTAMP 只适合 TIMESTAMP 类型的字段.
CREATE TABLE USER(
  ...
  create_time timestamp NULL default CURRENT_TIMESTAMP,    -- 默认为当前时间
  ...
)

字段类型的选取原则

  • 字段类型优先级 : 整型 > date,time > char,varchar > blob

原因:整型运算快, 且节省空间. char, varchar 要考虑字符集的转换与排序时的校对集, 所以速度慢.

  • 优先选择占空间小的类型.

原因 : 小空间的类型占用的磁盘, 内存, CPU 缓存, CPU 处理时间都更少.

  • 对于字符型和数字型, 优先选择数字型.

比如 : 应该使用整型来存储 IP 地址, 而不是字符型. 应该使用日期时间类型来存储日期时间, 而不是字符型.

  • 对于 char 和 varchar

如果列中的数据长度差不多一致, 比如 : 身份证号, 学号等, 则应该考虑使用 char 类型.

对于那些长度未知的字符串, 使用 varchar.

如果列中的最大数据长度小于 50 Byte (15个字符左右), 则一般考虑使用 char.

  • 对于 decimal 和 float:

精确数据只能使用 decimal 类型.

非精确数据优先使用 float 类型, ( float 比 decimal 的存储空间小 )

  • 对于那些可能值很有限的列, 使用 tinyint 代替 varchar / int

比如记录移动设备平台, 只有两个值:android, ios, 那么就可以使用 0 表示 android, 1 表示 ios, 并写好注释.

  • 不要滥用 bigint, 比如文章表的主键 id 字段, 用 int 就行了, 21 亿篇文章的上限足够使用了.

以上原则主要是从以下角度考虑 :

  • 查询速度:定长数据比变长数据查询快, 因为定长数据与数据之间的偏移是固定的, 很容易计算下一个数据的偏移.

而变长数据则还需要多一步去查询下一个数据的偏移量. 不过定长数据可能会浪费更多的存储空间.

  • 排序速度:在对数据进行比较 ( 查询条件, JOIN 条件以及排序 ) 操作时, 同样的数据, 数字的处理比字符串快.

字符串的比较与当前的排序规则有关, 它需要去查询当前排序规则的字典顺序, 而数字不需要.

到此这篇关于MySQL 数据类型及最优选取规则的文章就介绍到这了,更多相关MySQL 数据类型内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL 数据类型及最优选取规则

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL数据类型转换规则

MySQL支持多种数据类型的转换,这些规则主要涉及以下几个方面:整数类型转换:TINYINT可以转换为SMALLINT,SMALLINT可以转换为MEDIUMINT,MEDIUMINT可以转换为INT,INT可以转换为BIGINT。在进行
MySQL数据类型转换规则
2024-10-20

MySQL 数据类型选择原则

目录小而美简单至上避免空值选择数据类型的步骤数据类型介绍一、串数据类型二、数值数据类型三、日期和时间数据类型四、二进制数据类型结语:小而美通常来说,尽可能使用占用存储空间小的数据类型来存储数据。这类数据类型通常也会更快,并且占用的磁盘空间、
2022-05-14

MySQL数据类型优化原则

MySQL支持的数据类型很多,选择正确的数据类型对于高性能至关重要。下面几个简单的原则都有助于做出更好的选择。更小的通常更好应该尽量使用可以正确储存数据的最小数据类型。更小的数据类型通常更快,因为它们占用更少的磁盘、内存和CPU缓存,并且处
2022-05-31

深入理解MySQL数据类型的选择优化

目录前言1 整数类型2 实数类型3 字符串类型3.1 VARCHAR和CHAR类型3.1.1 最大长度3.2 Binary和VarBinary类型3.3 BLOB和TEXT类型3.3 ENUM类型4 日期和时间类型5 位数据类型6 选择优化
2022-08-10

MySQL中性别字段最佳数据类型选择是什么?

在设计数据库表时,选择合适的数据类型对于性能优化和数据存储效率非常重要。在MySQL数据库中,存储性别字段的数据类型真是没有所谓的最佳选择,因为性别字段一般只有两个取值:男或女。但是为了效率和节省空间,我们可以选择合适的数据类型来存储性别字
MySQL中性别字段最佳数据类型选择是什么?
2024-03-14

如何实现MySQL底层优化:数据类型选择与存储空间的最佳实践

抱歉,由于您要求包含具体的代码示例,我无法在此处提供中文文章。
如何实现MySQL底层优化:数据类型选择与存储空间的最佳实践
2023-11-08

MySQL基础教程4 —— 数据类型之存储需求及如何选择正确的类型

1. 列类型存储需求 根据类别列出了MySQL支持的每个列类型的存储需求。 MyISAM表中行的最大大小为65,534字节。每个BLOB和TEXT列 账户只占其中的5至9个字节。 如果MyISAM表包括变长列类型,记录格式也是可变长度。当创
2022-05-23

如何实现MySQL底层优化:数据类型选择与存储空间优化

MySQL是一款广泛使用的关系型数据库管理系统,其底层优化对于数据库的性能和稳定性至关重要。本文将对MySQL数据类型选择与存储空间优化进行详细介绍,并给出具有实际意义的代码示例。一、数据类型选择与优化1.常见数据类型介绍MySQL支持多种
如何实现MySQL底层优化:数据类型选择与存储空间优化
2023-11-08

mysql 数据库 不同数据类型字段设置长度大小、取值范围 及 存储空间

学习目标: 学习的目标 了解不同数据类型字段设置长度大小,从而 在使用 mysql 数据时为使用的字段设置适当的长度 。 学习内容: 学习的内容 整数型字符串型TEXT时间型 总结: 提示:总结 1、整数型 1、整数型的数值类型已
2023-08-16

编程热搜

目录