mysql数据类型选择

举报
别团等shy哥发育 发表于 2023/06/23 16:17:29 2023/06/23
【摘要】 1、整数和浮点数如果不需要小数部分,就是用整数来保存数据;如果需要小数部分,就是用浮点数。对于浮点数据列,存入的数值会对该列定义的小数位进行四舍五入。浮点类型包裹FLOAT和DOUBLE类型,精度要求较高时,使用DOUBLE类型。 2、浮点数和定点数浮点数FLOAT、DOUBLE相对于定点数DECIMAL的优势是:在长度一定的条件下,浮点数能表示更大的数据范围。但是由于浮点数容易产生误差,...

1、整数和浮点数

如果不需要小数部分,就是用整数来保存数据;如果需要小数部分,就是用浮点数。对于浮点数据列,存入的数值会对该列定义的小数位进行四舍五入。
浮点类型包裹FLOATDOUBLE类型,精度要求较高时,使用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类型。
ENUMSET的值是以字符串的形式出现的,但是在MYSQL内部以数值的形式存储它们。

6、BLOB和TEXT

BLOB是二进制字符串,TEXT是非二进制字符串,两者均可存放大容量的信息。BLOB主要存储图片、音频信息等,而TEXT只能存储文本文件。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。