【MySQL】数据类型
亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《【MySQL】数据类型》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下MySQL、数据库,希望所有认真读完的童鞋们,都有实质性的提高。
数值类型
| 整数类型 | 字节 | 最小值 | 最大值 |
|---|---|---|---|
| TINYINT | 1 | 有符号 $-2^7$ 无符号 0 | 有符号 $2^7-1$ 无符号 $2^8-1$ |
| SMALLINT | 2 | 有符号 $-2^{15}$ 无符号 0 | 有符号 $2^{15}-1$ 无符号 $2^{16}-1$ |
| MEDIUMINT | 3 | 有符号 $-2^{23}$ 无符号 0 | 有符号 $2^{23}-1$ 无符号 $2^{24}-1$ |
| INT、INTEGER | 4 | 有符号 $-2^{31}$ 无符号 0 | 有符号 $2^{31}-1$ 无符号 $2^{32}-1$ |
| BIGINT | 8 | 有符号 $-2^{63}$ 无符号 0 | 有符号 $2^{63}-1$ 无符号 $2^{64}-1$ |
| 浮点数类型 | 字节 | 最小值 | 最大值 |
|---|---|---|---|
| FLOAT | 4 | $\pm1.175494351E-38$ | $\pm3.402823466E+38$ |
| DOUBLE | 8 | $\pm2.2250738585072014E-308$ | $\pm1.7976931348623157E+308$ |
| 定点数类型 | 字节 | 描述 |
|---|---|---|
| DEC(M,D), DECIMAL(M,D) | M+2 | 最大取值范围与 DOUBLE 相同,给定 DECIMAL 的有效取值范围由M和D决定 |
整数类型
在整数类型中,按照取值范围和存储方式不同,分为 tinyint 、smallint、mediumint、int 和 bigint 这 5 个类型。如果超出类型范围的操作,会发生 “Out of range” 错误提示
对于整型数据,MySQL 还支持在类型名称后面的小括号内指定显示宽度,例如
int(5)表示当数值宽度小于 5 位的时候在数字前面填满宽度,如果不显式指定宽度则默认为
int(11)。如果配合 zerofil 使用时,数字位数不够的空间用字符 0 填满。
设置宽度后,如果插入大于宽度限制的值,不会对插入的数据有任何影响,还是按照类型的实际精度进行保存,这时,宽度格式实际已经没有意义。
很多的整数类型都有一个可选属性 UNSIGNED(无符号),如果需要在字段里面保存非负数或者需要较大的上限值时,可以用此选项,它的取值范围是正常值的下限取 0,上限取原值的 2 倍。如果一个列指定为 zerofill,则 MySQL 自动为该列添加 UNSIGNED 属性。
另外,整数类型还有一个属性:AUTO_INCREMENT。在需要产生唯一标识符或顺序值时,可利用此属性,这个属性只用于整数类型。值一般从 1 开始,每行增加 1。一个表中最多只能有一个 AUTO_INCREMENT 列。对于任何想要使用 AUTO_INCREMENT 的列,应该定义为 NOT NULL,并定义为 PRIMARY KEY 或者定义为 UNIQUE 键。
小数类型
小数类型分为两种:浮点数和定点数。
浮点数包括 float(单精度)和 double(双精度),而定点数则只有 decimal 一种表示。
定点数在 MySQL 内部以字符串形式存放,比浮点数更精确,适合用来表示货币等精度高的数据。
浮点数和定点数都可以用类型名称后加(M,D)的方式来进行表示,表示该值一共 M 位数字(整数位+小数位),其实 D 表示小数位的长度,M 和 D 又称为精度和标度。在不指定精度时,默认会按照实际的精度(由实际的硬件和操作系统决定)来显示,而 decimal 在不指定精度时,默认的整数位为 10,默认的小数位为 0。需要注意的是,浮点数后面跟(M,D)的用法是非标准用法,如果要用于数据库的迁移,则最好不要这么使用。
MySQL 在保存值时,如果小数位长度超过 D 值,当该列为浮点类型时,会进行四舍五入,如果是定点数时,会将超出的丢掉。
日期时间类型
| 日期和时间类型 | 字节 | 最小值 | 最大值 |
|---|---|---|---|
| DATE | 4 | 1000-01-01 | 9999-12-31 |
| DATETIME | 8 | 1000-01-01 00:00:00 | 9999-12-31 23:59:59 |
| TIMESTAMP | 4 | 19700101080001 | 2038年的某个时刻 |
| TIME | 3 | -839:59:59 | 839:59:59 |
| YEAR | 1 | 1901 | 2155 |
TIMESTAMP 和 DATETIME 的区别:
- TIMESTAMP 支持的时间范围较小,其取值范围从 19700101080001 到 2038 年的某个时间,因此不适合存放比较久远的日期,而 DATETIME 是从 1000-01-01 00:00:00 到 9999-12-31 23:59:59,范围更大。
- 表中的第一个 TIMESTAMP 列自动设置为系统时间。当插入的值超出取值范围时,MySQL 认为该值溢出,使用 0000-00-00 00:00:00 进行填补。
- TIMESTAMP 的插入和查询都受到当地时区的影响,更能反映出实际的日期。DATETIME 只能反映出插入时当地的时区,其它时区的人查看数据必然会有误差的。
字符串类型
| 字符串类型 | 字节 | 描述及存储需求 |
|---|---|---|
| CHAR(M) | M | M 为0~255之间的整数 |
| VARCHAR(M) | M 为0~65535之间的整数,值的长度+1个字节 | |
| TINYBLOB | 允许长度0~255字节,值的长度+1个字节 | |
| BLOB | 允许长度0~65535字节,值的长度+2个字节 | |
| MEDIUMBLOB | 允许长度0~167772150字节,值的长度+3个字节 | |
| LONGBLOB | 允许长度0~4294967295字节,值的长度+4个字节 | |
| TINYTEXT | 允许长度0~255字节,值的长度+2个字节 | |
| TEXT | 允许长度0~65525字节,值的长度+2个字节 | |
| MEDIUMTEXT | 允许长度0~167772159字节,值的长度+3个字节 | |
| LONGTEXT | 允许长度0~4294967295字节,值的长度+4个字节 | |
| VARBINARY(M) | 允许长度0~M个字节的变长字节字符串,值的长度+1个字节 | |
| BINARY(M) | M | 允许长度0~M个字节的定长字节字符串 |
CHAR 和 VARCHAR 类型
- CHAR 列的长度固定为创建表时声明的长度,长度可以为从 0~255 的任何值,存储时,如果字符数没有达到定义的位数,会在后面用空格补全入数据库中;VARCHAR 列中的值可变长字符串,如果没有达到定义的位数,也不会在后面补空格。
- 在获取数据时,CHAR 列会把后面的空格全部丢弃掉;取 VARCHAR 数据时尾部空格会保留。
MySQL 其他内容可以参考MySQL目录
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。
【MySQL】运算符及常见函数
- 上一篇
- 【MySQL】运算符及常见函数
- 下一篇
- Mysql 简单查询语句汇总
-
- 数据库 · MySQL | 1天前 |
- MySQL数值函数大全及使用技巧
- 117浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- 三种登录MySQL方法详解
- 411浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL数据备份方法与工具推荐
- 420浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL数据备份方法与工具推荐
- 264浏览 收藏
-
- 数据库 · MySQL | 4天前 |
- MySQL索引的作用是什么?
- 266浏览 收藏
-
- 数据库 · MySQL | 5天前 |
- MySQL排序原理与实战应用
- 392浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQLwhere条件查询技巧
- 333浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL常用数据类型有哪些?怎么选更合适?
- 234浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL常用命令大全管理员必学30条
- 448浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL高效批量插入数据方法大全
- 416浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL性能优化技巧大全
- 225浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL数据备份4种方法保障安全
- 145浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3167次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3380次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3409次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4513次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3789次使用
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览

