mysql数据类型的选择
1、整数和浮点数
如果不需要小数部分,就是用整数来保存数据;如果需要小数部分,就是用浮点数。对于浮点数据列,存入的数值会对该列定义的小数位进行四舍五入。
浮点类型包裹FLOAT
和DOUBLE
类型,精度要求较高时,使用DOUBLE
类型。
2、浮点数和定点数
浮点数FLOAT、DOUBLE
相对于定点数DECIMAL
的优势是:在长度一定的条件下,浮点数能表示更大的数据范围。但是由于浮点数容易产生误差,因此对精确度的要求比较高时,建议使用DECIMAL
存储。另外,两个浮点数进行减法和比较运算时容易出问题,因此在进行计算的时候一定要小心。如果进行数值比较,那么最好使用DECIMAL类型。
3、日期与时间类型
若只需要记录年份,用YEAR
类型
若只需要记录时间,则只需使用TIME类型
若同时需要记录日期和时间,则可以使用TIMESTAMP
或者DATETIME
类型。由于TIMESTAMP
列的取值范围小于DATETIME
的取值范围,因此存储范围较大的日期最好使用DATETIME
4、CHAR和CARCHAR
CHAR
是固定长度字符,VARCHAR
是可变长度字符。CHAR
会自动删除插入数据的尾部空格,VARCHAR
不会删除尾部空格CHAR
是固定长度,所以处理速度比VARCHAR
快,但是浪费存储空间。
5、ENUM与SET
ENUM
只能取单个值,它的数据列表是一个枚举集合。它的合法列表最多有65535个成员。因此,在需要从多个值中选取一个时,可以使用ENUM
.比如性别字段适合定义为ENUM
类型,每次只能从男或女中取一个值。
SET
可取多个值。它的合法列表最多有64个成员。空字符串也是一个合法的SET
值。在需要取多个值的时候,时合使用SET类型。比如,一个人的兴趣爱好,最好使用SET
类型。
ENUM
和SET
的值是以字符串的形式出现的,但是在MYSQL
内部以数值的形式存储它们。
6、BLOB和TEXT
BLOB
是二进制字符串,TEXT
是非二进制字符串,两者均可存放大容量的信息。BLOB
主要存储图片、音频信息等,而TEXT
只能存储文本文件。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?