[转载]MySQL之char、varchar和text的设计
[转载]MySQL之char、varchar和text的设计
来源:https://www.cnblogs.com/billyxp/p/3548540.html
首先我们先普及一下常识:
1、char(n)和varchar(n)中括号中n代表字符的个数,并不代表字节个数,所以当使用了中文的时候(UTF8)意味着可以插入n个中文,但是实际会占用m*3个字节。
2、同时char和varchar最大的区别就在于char不管实际value都会占用n个字符的空间,而varchar只会占用实际字符应该占用的空间+1,并且实际空间+1<=n。
3、超过char和varchar的n设置后,字符串会被截断。
4、char的上限为255字节,varchar的上限65535字节,text的上限为65535,和varchar一样。
5、char在存储的时候会截断尾部的空格,varchar和text不会。
6、varchar会使用1-3个字节来存储长度,text不会。
下图可以非常明显的看到结果:
Value CHAR(4) Storage Required VARCHAR(4) Storage Required '' ' ' 4 bytes '' 1 byte 'ab' 'ab ' 4 bytes 'ab' 3 bytes 'abcd' 'abcd' 4 bytes 'abcd' 5 bytes 'abcdefgh' 'abcd' 4 bytes 'abcd' 5 bytes 总体来说:
1、char,存定长,速度快,存在空间浪费的可能,会处理尾部空格,上限255。
2、varchar,存变长,速度慢,不存在空间浪费,不处理尾部空格,上限65535,但是有存储长度实际65532最大可用。
3、text,存变长大数据,速度慢,不存在空间浪费,不处理尾部空格,上限65535,会用额外空间存放数据长度,顾可以全部使用65535。
接下来,我们说说这个场景的问题:
当varchar(n)后面的n非常大的时候我们是使用varchar好,还是text好呢?这是个明显的量变引发质变的问题。我们从2个方面考虑,第一是空间,第二是性能。
首先从空间方面:
从官方文档中我们可以得知当varchar大于某些数值的时候,其会自动转换为text,大概规则如下:
- 大于varchar(255)变为 tinytext
- 大于varchar(500)变为 text
- 大于varchar(20000)变为 mediumtext
所以对于过大的内容使用varchar和text没有太多区别。
其次从性能方面:
索引会是影响性能的最关键因素,而对于text来说,只能添加前缀索引,并且前缀索引最大只能达到1000字节。
而貌似varhcar可以添加全部索引,但是经过测试,其实也不是。由于会进行内部的转换,所以long varchar其实也只能添加1000字节的索引,如果超长了会自动截断。
最新文章
- [LeetCode] LRU Cache 最近最少使用页面置换缓存器
- Vue2随笔
- 利用 iframe解决ajax的跨域问题
- Java数组,去掉重复值、增加、删除数组元素
- 每天一个linux命令(27):ln 命令
- linux下proc目录详解
- HDOJ 1085 Holding Bin-Laden Captive! (母函数)
- Codeforces Round #253 (Div. 1) A. Borya and Hanabi 暴力
- 通过百度地图API定位--第三方开源--百度地图(一)
- asp.net mvc cooike 购物车 如何实现
- Spring学习笔记——Spring中的BeanFactory与FactoryBean
- poi读写Excel文件
- Eclipse中搭建Python开发环境
- dlib库学习之一
- Dubbo源码学习--服务是如何发布的
- 【转】程序员必须知道的几个Git代码托管平台
- rails项目编写中的一些小技巧小心得
- Java并发编程:CountDownLatch、CyclicBarrier和 Semaphore
- [Python设计模式] 第7章 找人帮忙追美眉——代理模式
- 聊天对话框(ctrl+enter发送)
热门文章
- (十一)C语言之选择结构
- Java-JDK-windows和linux版-百度云下载
- 石川es6课程---13-16、generator-认识生成器函数
- 码云上webide怎么提交
- TensorFlow 学习(3)——MNIST机器学习入门
- [svc]linux中的文件描述符(file descriptor)和文件
- 小程序API:wx.showActionSheet 将 itemList动态赋值
- pandas之数据选择
- 阶段3 3.SpringMVC&#183;_06.异常处理及拦截器_6 SpringMVC拦截器之拦截器入门代码
- jq 点击除了某元素以外的其他所有元素