MySQL数据类型(2)

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 subsetring(column,length)

Mysql不能将blob和text列全部长度的字符串进行索引,也不能使用这些索引消除排序

日期和时间类型
在这里插入图片描述

Datetime使用8个字节的存储空间和时区无关
Timestamp使用4个字节的存储空间,显示的时间依赖时区,保存了1970年1月1号物午夜(格林斯顿标准时间)以来的秒数,他和Unix的时间戳相同,timestamp只能表示从1970到2038年

例如,如果存储一个值b^00111001’(十进制的值为57)到bit( 8)的列并检索它时得到的结果是9(9的ascll码是57)如果对该字段进行加减,则返回结果 57
Json类型
Mysql8支持直接存储json格式字符串,对应的是json数据类型
1、 json数据列会自动验证json的数据格式,如果格式不正确会报错
2、 最优化存储格式,json数据类型会把json格式的字符串转换成内部各式,能够快速的读取其中的元素

小结:
1、 更小的更好
选择你认为不会超越范围的最小类型,更小的数据类型通常更快,因为它们占用更少的磁盘,内存和cpu缓存,并且处理时需要的CPU周期更少

2、 简单就好
简单的数据类型操作通常更快,例如整形的操作比字符串更快,因为字符串符集和对规则(排序规则)比整形更复杂

3、 尽量避免null
如果字段可以不存储null值,尽量把字段设置not null,因为可为null的列使得索引,索引统计和值比较更复杂,可为null的列会使用更多的存储空间,在mysql里也需要特殊处理

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值