当前位置:网站首页>Mysql数据类型
Mysql数据类型
2022-08-04 10:52:00 【pmc0_0】
mysql数据类型
类型 | 类型举例 |
---|---|
整数类型 | TINYINT、SMALLINT、MEDIUMINT、INT(或INTEGER)、BIGINT |
浮点类型 | FLOAT、DOUBLE |
定点数类型 | DECIMAL |
位类型 | BIT |
日期时间类型 | YEAR、TIME、DATE、DATETIME、TIMESTAMP |
文本字符串类型 | CHAR、VARCHAR、TINYTEXT、TEXT、MEDIUMTEXT、LONGTEXT |
枚举类型 | ENUM |
集合类型 | SET |
二进制字符串类型 | BINARY、VARBINARY、TINYBLOB、BLOB、MEDIUMBLOB、LONGBLOB |
JSON类型 | JSON对象、JSON数组 |
空间数据类型 | 单值类型:GEOMETRY、POINT、LINESTRING、POLYGON;集合类型:MULTIPOINT、MULTILINESTRING、MULTIPOLYGON、GEOMETRYCOLLECTION |
数据类型属性
MySQL关键字 | 含义 |
---|---|
NULL | 数据列可包含NULL值 |
NOT NULL | 数据列不允许包含NULL值 |
DEFAULT | 默认值 |
PRIMARY KEY | 主键 |
AUTO_INCREMENT | 自动递增,适用于整数类型 |
UNSIGNED | 无符号 |
CHARACTER SET name | 指定一个字符集 |
整数类型介绍
整数类型 | 字节数(一字节等于8位) |
---|---|
TINYINT | 1 |
SMALLINT | 2 |
MEDIUMINT | 3 |
INT、INTEGER | 4 |
BIGINT | 8 |
适用场景
- TINYINT:一般用于枚举数据,比如系统设定取值范围很小且固定的场景。
- SMALLINT:可以用于较小范围的统计数据,比如统计工厂的固定资产库存数量等。
- MEDIUMINT:用于较大整数的计算,比如车站每日的客流量等。
- INT、INTEGER:取值范围足够大,一般情况下不用考虑超限问题,用得最多。比如商品编号。
- BIGINT:只有当你处理特别巨大的整数时才会用到。比如双十一的交易量、大型门户网站点击量、证券公司衍生产品持仓等。
浮点类型
浮点数和定点数类型的特点是可以 处理小数 ,你可以把整数看成小数的一个特例。因此,浮点数和定点数的使用场景,比整数大多了。 MySQL支持的浮点数类型,分别是 FLOAT、DOUBLE、REAL。
- FLOAT 表示单精度浮点数,占用4个字节
- DOUBLE 表示双精度浮点数,占用8个字节
定点类型
MySQL中的定点数类型只有 DECIMAL 一种类型。计算是没有精度损失的,但浮点型会有,涉及金钱的就要用定点数据类型
开发经验
“由于 DECIMAL 数据类型的精准性,在我们的项目中,除了极少数(比如商品编号)用到整数类型外,其他的数值都用的是 DECIMAL,原因就是这个项目所处的零售行业,要求精准,一分钱也不能差。 ” ——来自某项目经理
日期类型
- YEAR 类型通常用来表示年
- DATE 类型通常用来表示年、月、日
- TIME 类型通常用来表示时、分、秒
- DATETIME 类型通常用来表示年、月、日、时、分、秒
- TIMESTAMP 类型通常用来表示带时区的年、月、日、时、分、秒
时间类型 | 表示 | 字节数(一字节等于8位) |
---|---|---|
YEAR | 年 | 1 |
TIME | 时间 | 3 |
DATE | 日期 | 3 |
DATETIME | 日期时间 | 8 |
TIMESTAMP | 日期时间 | 4 |
TIMESTAMP和DATETIME的区别:
- TIMESTAMP存储空间比较小,表示的日期时间范围也比较小
- 两个日期比较大小或日期计算时,TIMESTAMP更方便、更快。
一般存注册时间、商品发布时间等,不建议使用DATETIME存储,而是使用 时间戳 ,因为DATETIME虽然直观,但不便于计算。
字符串类型
MySQL4.0版本以下,varchar(20):指的是20字节,如果存放UTF8汉字时,只能存6个(每个汉字3字节) ;MySQL5.0版本以上,varchar(20):指的是20字符,可以存20个(一个utf汉字算一个字符)。
| 字符串(文本)类型 | 特点 | 长度 | 长度范围 | 占用的存储空间 |
字符串(文本)类型 | 特点 | 长度 | 长度范围 | 占用的存储空间 |
---|---|---|---|---|
CHAR(M) | 固定长度 | M | 0 <= M <= 255 | M个字节 |
VARCHAR(M) | 可变长度 | M | 0 <= M <= 65535 | (实际长度 + 1) 个字节 |
char
- 定义CHAR类型字段时,声明的字段长度即为CHAR类型字段所占的存储空间的字节数。
- CHAR(M) 类型一般需要预先定义字符串长度。如果不指定(M),则表示长度默认是1个字符。
varchar
- 检索VARCHAR类型的字段数据时,会保留数据尾部的空格。VARCHAR类型的字段所占用的存储空间为字符串实际长度加1个字节。
- VARCHAR(M) 定义时, 必须指定 长度M,否则报错。
情景比较
- 存储很短的信息。比如门牌号码101,201……这样很短的信息应该用char,因为varchar还要占个byte用于存储信息长度,本来打算节约存储的,结果得不偿失。
- 十分频繁改变的column。因为varchar每次存储都要有额外的计算,得到长度等工作,如果一个非常频繁改变的,那就要有很多的精力用于计算,而这些对于char来说是不需要的。
具体存储引擎考量
- MyISAM 数据存储引擎和数据列:MyISAM数据表,最好使用固定长度(CHAR)的数据列代替可变长度(VARCHAR)的数据列。这样使得整个表静态化,从而使 数据检索更快 ,用空间换时间。
- MEMORY 存储引擎和数据列:MEMORY数据表目前都使用固定长度的数据行存储,因此无论使用CHAR或VARCHAR列都没有关系,两者都是作为CHAR类型处理的。
- InnoDB 存储引擎,建议使用VARCHAR类型。因为对于InnoDB数据表,内部的行存储格式并没有区分固定长度和可变长度列(所有数据行都使用指向数据列值的头指针),而且主要影响性能的因素是数据行使用的存储总量,由于char平均占用的空间多varchar,所以除了简短并且固定长度的,其他考虑varchar。这样节省空间,对磁盘I/O和数据存储总量比较好。
边栏推荐
- Win11 file types, how to change?Win11 modify the file suffix
- Apache Calcite 框架原理入门和生产应用
- JUC (1) threads and processes, concurrency and parallelism, thread state, locks, producers and consumers
- Jenkins使用手册(1) —— 软件安装
- 标准C语言学习总结12
- 无代码平台附件上传入门教程
- Mysql高级篇学习总结13:多表连接查询语句优化方法(带join语句)
- 强烈推荐一款优秀且通用的后台管理系统
- iMeta | 百度认证完成,搜索“iMeta”直达出版社主页和投稿链接
- mae,mse,rmse分别利用sklearn和numpy实现
猜你喜欢
随机推荐
【Idea系列】idea配置
什么是终端特权管理
解决:WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING
RL78开发环境
热成像测温的原理是什么呢?你知道吗?
DB2查看执行过长的SQL
Camunda整体架构和相关概念
八、MFC对话框
linux下数据库初始化密码
利用pytest hook函数实现自动化测试结果推送企业微信
Business collocations
Servlet基础详细版
开源一夏|ArkUI如何自定义弹窗(eTS)
8月活动|51CTO十七周年庆,发博文得茶具/笔记本/T恤等礼品!
ThreadLocal详细分析
map的一道题目<单词识别>
Use pytest hook function to realize automatic test result push enterprise WeChat
【Inspirational】The importance of review
如何直击固定资产管理的难题?
再次搞定 Ali 云函数计算 FC