Mysql——数据类型

整数类型

 适用场景:

 

 选择原则首先确保数据不会超过取值范围,在这个前提之下,再去考虑如何节省存储空间。

浮点类型

FLOAT、DOUBLE:处理小数,前者表示单精度浮点数,后者表示双精度浮点数,也就是后者表示的范围更广,占用字节更多。

FLOAT(M,D)  DOUBLE(M,D):非标准语法,M为精度,也就是小数位+整数位;D为标度,也就是小数位。

存储问题:在存储时,整数超过范围会报错;小数超过范围会进行四舍五入,但是四舍五入后如果整数部分超过范围也会报错。

精度误差:浮点数是不准确的,0.47+0.44+0.19 != 1.1。所以我们要避免使用“=”来判断两个数是否相等

定点数类型 

DECIMAL(M,D):M为精度,D为标度。所占存储空间为M+2个字节。默认为DECIMAL(10,0)。

浮点数VS定点数:浮点数在长度一定的情况下,浮点类型取值范围大,但是不精准,适用于需要取值范围大,又可以容忍微小误差的科学计算场景;定点数类型取值范围相对小,但是精准,没有误差,适合于对精度要求极高的场景 (比如涉及金额计算的场景)。

日期和时间类型

使用 CURRENT_DATE() 或者 NOW() 函数,会插入当前系统的日期。

但是在实际项目中,尽量用 DATETIME 类型。此外,一般存注册时间、商品发布时间等,不建议使用DATETIME存储,而是使用TIMESTAMP ,因为DATETIME虽然直观,但不便于计算。

文本字符串类型

CHAR类型: CHAR(M) 类型一般需要预先定义字符产长度,不定义为1个字符。长度不够右侧空格填充,检索时会去除尾部空格。
 
VARCHAR类型: VARCHAR(M) 定义时, 必须指定 长度 M ,否则报错。它会占用额外的1字节存储字符串实际长度。
存储信息短以及存储信息长度固定使用CHAR类型,其他使用VARCHAR类型。
TEXT类型:用来保存文本类型的字符串。
TEXT 文本类型,可以存比较大的文本段,搜索速度稍慢,因此如果不是特别大的内容,建议使用 CHAR VARCHAR 来代替。该类型数据删除后容易导致“空洞”,使得文件碎片较多。

ENUM类型

枚举类型,ENUM 类型的取值范围需要在定义字段时进行指定。
不能一次选取多个值,忽略大小写,同时可以使用索引进行枚举元素的调用

SET类型

表示一个字符串对象,可以包含 0个或多个成员,但成员个数的上限为64, 可以取取值范围内的 0 个或多个值。

二进制字符串类型

主要存储一些二进制数据,比如可以存储图片、音频和视频等二进制数据。
BINARYVARBINARY类型: 类似于 CHAR、 VARCHAR ,只是它们存储的是二进制字符串。
BLOB类型: 可以存储一个二进制的大对象,比如图片、音频和视频等。

总结

在定义数据类型时,如果确定是整数 ,就用 INT ; 如果是小数 ,一定用定点数类型DECIMAL(M,D) ; 如果是日期与时间,就用 DATETIME 。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值