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

MySQL之数据类型

来源:SegmentFault 2023-01-10 15:40:47 0浏览 收藏

积累知识,胜过积蓄金银!毕竟在##column_title##开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《MySQL之数据类型》,就带大家讲解一下MySQL知识点,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

一、VARCHAR与CHAR

这两者都是用来表示字符串的数据类型。

VARCHAR

VARCHAR属于可变长的字符串,相对于定长的字符串会更加节省存储空间。在存储数据的时候VARCHAR变量需要在原有的数据大小的基础上额外使用1或2个字节记录字符串的长度(当列的最大长度小于等于255时,使用1个字节记录,否则使用2个字节记录)。由于长度可变的特性,使得VARHCHAR类型的数据在UPDATE的时候耗时会更久。且在存储时会在VARCHAR类型数据的最后添加一个空格(可以理解成为长度改变所做的准备)。
下面情况使用VARCHAR类型是合适的:字符串列的最大长度比平均长度大很多(即字符串长度都比较短);列的更新比较少。

CHAR

CHAR是定长的字符串,MySQL会根据字符串的长度分配足够的空间,且会在存储数据的时候剔除数据最后的空格。
CHAR类型适合存储长度较短且列的数据长度基本一致的数据;对于经常变更的数据也适合采用CHAR值,因为不会像VARCHAR的可变特性一样产生存储碎片的问题。
创建一个存储char字符串的表格:

mysql> CREATE TABLE char_test(char_col CHAR(10));

插入几条数据:

mysql> INSERT INTO char_test(char_col) VALUES 
('string1'),(' string2'),('string3   ');

注意此时第二个数据的开头与第三个数据的结尾存在空格。
查看结果:

mysql> SELECT * FROM char_test;
+----------+
| char_col |
+----------+
| string1  |
|  string2 |
| string3  |
+----------+
3 rows in set (0.00 sec)

会发现第二个数据开头的空格得以保留,而第三个数据结尾的空格被移除了,这也就验证了我们上面所说的CHAR类型在存储数据的时候会自动剔除结尾的空格。
为了对比我们再做一个VARCHAR类型的数据,添加相同的数据得到的结果是:

mysql> SELECT * FROM varchar_test;
+-------------+
| varchar_col |
+-------------+
| string1     |
|    string2  |
| string3     |
+-------------+
3 rows in set (0.00 sec)

第三个数据结尾的空格得以保留。

二、枚举(ENUM)类型

枚举类型其实和字符串类型非常相似,不同的是枚举类型在创建的时候就规定了这个字段所能使用的字符串的一个集合,之后该字段出现的字符串只能是枚举集合中存在的。这种情况虽然看似使得数据的操作变得不灵活,但是却因为这种先规定的特性使得数据在存储的时候能够被压缩的非常紧凑,节省了存储空间。
在一个表中创建一个枚举类型的字段:

mysql> CREATE TABLE enum_test(e ENUM('fish','apple','dog'));

上面的语句为表格创建了一个名为e的枚举字段,该字段所能出现的值就只有'fish'、'apple'和'dog',其他内容都不能出现在这个字段中。
但是MySQL在存储ENUM类型的数据的时候并不是按照'fish','apple','dog'这样的内容来存储的,而是存储他们的索引,即存储的内容是一个证整数。

mysql> INSERT INTO enum_test VALUES ('fish'),('apple'),('dog');
Query OK, 3 rows affected (0.00 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> SELECT * FROM enum_test;
+-------+
| e     |
+-------+
| fish  |
| apple |
| dog   |
+-------+
3 rows in set (0.00 sec)

mysql> SELECT e+0 FROM enum_test;
+------+
| e+0  |
+------+
|    1 |
|    2 |
|    3 |
+------+
3 rows in set (0.00 sec)

从第二个查询的结果可以看出在MySQL内部,'fish'存储的其实是0,'apple'存储的其实是1,'dog'存储的其实是2,即根据枚举定义的时候的定义顺序的一个编号。
让我们再看看另一个现象:

mysql> SELECT * FROM enum_test ORDER BY e;
+-------+
| e     |
+-------+
| fish  |
| apple |
| dog   |
+-------+
3 rows in set (0.00 sec)

如果此时的e数据类型是字符串类型,那么执行ORDER BY e之后e的内容会按照字母的顺序排列,但很显然,当前的情况并没有按照字母顺序排列,而是依然按照定义时候的顺序排列,其实也就是按照对应存储的那个整数进行排列的。

三、日期和时间类型

DATETIME

DATETIME类型表示的时间范围广(1001年-9999年),精度为秒,与时区无关,使用8个字节的空间存储。
DATETIM的显示格式:

mysql> SELECT * FROM time_test;
+---------------------+
| time                |
+---------------------+
| 2020-01-01 22:37:08 |
+---------------------+
1 row in set (0.00 sec)

TIMESTAMP

TIMESTAMP类型所表示的时间范围没有那么广(1970-2038),使用4个字节的空间存储。
TIMESTAMP显示的值依赖性时区,MySQL服务器,操作系统以及客户端连接都能够进行时区的设置。这就意味着在多个时区存储或者访问数据,TIMESTAMP类型保存的值和DATETIME类型将很不一样,前者提供的值与时区有关系,后者则保留文本表示的日期和时间。
除了特殊情况外,都推荐使用TIMESTAMP来存储,因为它的空间效率比DATETIME更高。
如果存储的时间的精度需要比秒更小的粒度怎么办?MySQL目前还没有提供合适的数据类型,可以使用MariaDB。

四、选择优化的数据类型

更小的可能更好

指的是在确保数据类型能够满足该数据要求范围的情况下,应该使用尽可能小的数据类型。因为使用范围过大的数据类型会对性能与空间产生一定的消耗,特别是当数据量多的时候查询的效率会受到一定的影响。

简单就好

简单的数据类型操作通常会更加快捷与高效。例如,整数会比字符串的操作代价更低。有两个比较明显的例子:一是应该使用MySQL的内建类型(DATETIME,DATE,TIME)来存储时间和日期,而不是使用字符串来存储;二是应该使用整型存储IP地址。

尽量避免NULL

通常情况下最好指定列为NOT NULL,除非真的需要存储NULL值。使用NULL值后MySQL的优化将变得更加艰难,因为使用NULL将使得索引,索引统计以及值的比较都变得更加复杂;可为NULL的列也会占据更大的空间。

今天带大家了解了MySQL的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

版本声明
本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
最新版MySQL在MacOS上的安装与使用!最新版MySQL在MacOS上的安装与使用!
上一篇
最新版MySQL在MacOS上的安装与使用!
建库、建表、插入、查询数据一键操作
下一篇
建库、建表、插入、查询数据一键操作
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 笔灵AI生成答辩PPT:高效制作学术与职场PPT的利器
    笔灵AI生成答辩PPT
    探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
    12次使用
  • 知网AIGC检测服务系统:精准识别学术文本中的AI生成内容
    知网AIGC检测服务系统
    知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
    22次使用
  • AIGC检测服务:AIbiye助力确保论文原创性
    AIGC检测-Aibiye
    AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
    30次使用
  • 易笔AI论文平台:快速生成高质量学术论文的利器
    易笔AI论文
    易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
    38次使用
  • 笔启AI论文写作平台:多类型论文生成与多语言支持
    笔启AI论文写作平台
    笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
    35次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码