1、mysql数据类型

数值类型

整数类型

image.png

  • 整数类型有可选的unsigned属性,表示不允许负值,这可以使正数的上限提高一倍(还多1)。

  • 有符号和无符号类型使用相同的存储空间,并且具有相同的性能,因此可以根据实际情况选择合适的类型。

  • mysql可以为整数类型指定宽度,例如INT(11),对大多数应用来说这是没有意义的:它不会限制合法范围,只是规定了mysql的一些交互工具(例如mysql命令行客户端)用来显示字符的个数。对于存储和计算来说,INT(1)和INT(20)是相同的。

实数类型

image.png

FLOAT和DOUBLE的定义方式为:FLOAT(M,D)、DOUBLE(M,D),(M,D)表示该值一共显示M位整数,其中D位位于小数点后面。例如,定义为FLOAT(7,4)的一个列可以显示为-999.9999。MySQL保存值时进行四舍五入,因此如果在FLOAT(7,4)列内插入999.00009,近似结果是999.0001。

DECIMAL(5,2)其中M表示十进制数字总的个数,D表示小数点后面数字的位数,上例中的取值范围为-999.99~999.99。
如果存储时,整数部分超出了范围(如上面的例子中,添加数值为1000.01),MySql就会报错,不允许存这样的值。
如果存储时,小数点部分若超出范围,就分以下情况:

  • 若四舍五入后,整数部分没有超出范围,则只警告,但能成功操作并四舍五入删除多余的小数位后保存。如999.994实际被保存为999.99。
    
  • 若四舍五入后,整数部分超出范围,则MySql报错,并拒绝处理。如999.995和-999.995都会报错。
    
  • M的默认取值为10,D默认取值为0。如果创建表时,某字段定义为decimal类型不带任何参数,等同于decimal(10,0)。带一个参数时,D取默认值。 M的取值范围为1~65,取0时会被设为默认值,超出范围会报错。D的取值范围为0~30,而且必须<=M,超出范围会报错。
    

[

位数类型

在这里插入图片描述

BIT数据类型用于存储位值。一种BIT(M)允许存储_M位值。M可以从1到64不等。要指定位值,是使用零和1编写的二进制值。例如,b’111’和b’10000000’分别代表7和128。当为长度小于M位的BIT(M_)列分配一个值,则该值在左侧填充为零。例如,为BIT(6)列分配b’101’值实际上与分配b’000101’相同。

如果设置值超过位数的话,会从左边开始截除掉。

字符串类型

在这里插入图片描述

CHAR

CHAR类型是定长的,会根据定义的长度分配空间。当存储CHAR值时,mysql会删除所有的末尾空格。

CHAR很适合存储很短的字符串,或者所有的值都接近同一个长度,例如,CHAR非常适合存储密码的MD5的值,因为这是一个定长的长度。对于经常变动的数据,CHAR也比VARCHAR更好,因为定长的CHAR类型不容易产生碎片。

对于非常短的列,CHAR比VARCHAR在存储空间上也更有优势,例如用CHAR(1)来存储只有Y和N的值,如果采用单字节字符集只需1个字节,但是VARCHAR(1)却需要2个字节,因为还需要一个记录长度的额外字节。

VARCHAR

VARCHAR用于存储可变长的字符串,它比定长类型更节省空间。VARCHAR需要使用1或2个额外字节记录字符串的长度:如果列的最大长度小于或等于255字节,则只使用1个字节表示,如果列长度大于255字节,则需要使用2个字节表示长度。

假设采用latin字符集,一个VARCHAR(10)的列需要11个字节空间存储,一个VARCHAR(1000)的列则需要1002个字节空间存储,因为需要存储2个字节的长度信息。

哪些情况使用VARCHAR类型比较合适呢?

  • 字符串的列长度比平均长度大很多
  • 列的更新很少,碎片不是问题
  • 使用了想UTF-8这样复杂的字符集,每个字符都使用了不同的字节数进行存储

BINARY和VARBINARY

BINARY和VARBINARY它们存储的是二进制字符串。二进制字符串和常规的字符串非常相似,但是二进制字符串存储的字节码而不是字符。填充也不一样:mysql填充BINARY采用的是 \0(零字节)而不是空格,在检索时也不会去掉填充值。

当需要存储二进制数据时,可以使用 BINARY或VARBINARY,mysql比较二进制字符串时,每次按一个字节,并且根据该字节的数值进行比较。因此二进制比较比字符串比较简单的多,所以也更快。

BLOB和TEXT

BLOB和TEXT都是为了存储很大数据而设计的字符串数据类型,分别采用二进制和字符方式存储。

  • 二进制类型:TINYBLOB,BLOB,MEDIUMBLOB,LONGBLOB
  • 字符类型:TINYTEXT,TEXT,MEDIUMTEXT,LONGTEXT

与其他类型不同,mysql把每个BLOB和TEXT值当做一个独立的对象处理。存储引擎在存储是通常会做特殊处理,当BLOB和TEXT值太大时,InnoDB会使用专门的“外部”存储区域来进行存储,此时每个值在行内需要1~4个字节存储一个指针,然后在外部存储区域存储实际值。

BLOB和TEXT家族之间仅有的不同是,BLOB存储的是二进制数据,没有排序规则和字符集;而TEXT存储的是字符,有排序规则和字符集。

mysql对BLOB和TEXT列进行排序和其他数据类型不同:它只对每个列的前max_sort_length字节而不是整个字符串做排序。如果只需要排序前面的一小部分字符,则可以减少max_sort_length的值,或者使用ORDER BY SUBSTRING(column,length)

mysql不能将BLOB和TEXT列全部长度的字符串进行索引,也不能使用这些索引消除排序。

时间日期类型

在这里插入图片描述

DATETIME使用8个字节的存储空间,和时区无关。

TIMESTAMP使用4个字节的存储空间,显示的时间依赖时区,保存了从1970年1月1号午夜(格林尼治标准时间)以来的秒数,它和unix的时间戳相同。TIMESTAMP只能表示从1970年到2038年。

如果插入和更新数据时没有指定TIMESTAMP的值,mysql会默认的更新TIMESTAMP的值当前系统时间。

JSON类型

官网文档:https://dev.mysql.com/doc/refman/5.7/en/json.html

mysql8支持直接存储json格式字符串,对应的是json数据类型。

  • json数据列会自动验证json的数据格式,如果格式不正确会报错。
  • 最优化存储格式。json数据类型会把json格式的字符串转换成内部格式,能够快速的读取其中的元素。

对应json数据类型的操作方法有JSON_SET(), JSON_REPLACE(), JSON_REMOVE() 等

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值