当前位置:首页 > 站长资讯 > 正文内容

【说站】varchar与char在MySQL里面有什么区别?

yc8882年前 (2022-07-15)站长资讯238

varchar与char在MySQL里面有什么区别?

varchar与char是两种不同的数据类型,在MySQL中是有区别的,具体有以下区别:

区别一,存储数据长度不同

char表示定长,长度固定,char如果插入的长度小于定义长度时,则用空格填充,最大支持255个字符,即varchar(255)。

因为char类型在创建数据表的时候就将其分配的空间和字符长度设置好,如果后面存储的实际数据没有达到先前设置的长度,Mysql数据库会自动在后面用空格填充补齐。在读取数据的时候,MySQL会将字符后面多余的空格字符自动移除,(如果开始了PAD_CHAR_TO_FULL_LENGTHSQLMODE不会移除空格)。

varchar数据长度可变。varchar小于定义长度时,还是按实际长度存储,插入多长就存多长,varchar可以设置的最大长度是varchar(65535)。

varchar类型的数据列是可变长度的字符列,varchar可以设置的最大长度是varchar(65535),但是因为MySQL单行记录数据的localpage最大限制为65535字节(不含offpage),varchar列的长度设置也不能超过这个限制,即一行数据的所有列总大小不能超过65535字节。varchar类型的列因为存储时不会自动填充空格,所以在查询时也是原样检索,不过会过滤数据后面的空格。因为其长度固定,char的存取速度还是要比varchar要快得多,方便程序的存储与查找;但是char也为此付出的是空间的代价,因为其长度固定,所以会占据多余的空间,可谓是以空间换取时间效率。varchar则刚好相反,以时间换空间。

区别之二,存储的容量不同

对 char 来说,最多能存放的字符个数 255,和编码无关。而 varchar 呢,最多能存放 65535 个字符。varchar的最大有效长度由最大行大小和使用的字符集确定。整体最大长度是 65,535字节。

总结有以下几点:

1、char类型在字段创建时默认分配所有空间,最大支持255个字符,即varchar(255)。

2、varchar类型不默认分配空间,使用多少分配多少,最大支持长度为varchar(65535),但是受限于innodb单行记录不超过65535字节的限制。

3、char类型在数据写入时如果数据长度没有写满,会使用空格填充,读取的时候会自动过滤空格,varchar类型不会自动填充空格和过滤空格。

4、如果SQL MODE开启了严格模式(Strict SQL MODE),那么如果写入数据超过设置长度,则会报错,如果没有开启严格模式,那么数据会被截断写入,并且返回一个warning。

5、char字段类型如果字节数超过768,比如varchar(255)的utf8mb4编码字段,那么内部会转换成可变长度类型,将超过768的字节存储到off-page中。


本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://www.10zhan.com/zhanzhang/7337.html

分享给朋友:

“【说站】varchar与char在MySQL里面有什么区别?” 的相关文章

【说站】宝塔站点日志文件过大怎么办?网站日志切割教程

【说站】宝塔站点日志文件过大怎么办?网站日志切割教程

宝塔面板日志文件过大的原因?宝塔面板的网站日志文件默认是生成一个日志文件,然后系统每天不断的对这个文件进行写入操作,这样日子长了,这个日志文件就会越来越大,几百兆、几个G都是蛮正常的,这样对于我们分析...

【说站】Win10专业版如何激活?Win10激活工具

【说站】Win10专业版如何激活?Win10激活工具

本人用的Win10专业版一直用的好好地,今天桌面右下方就提示“激活Windows 转到设置以激活Windows”,因为一直用的是盗版Windows 10,出现这样的提示也蛮正常,没得办法,见招拆招,在...

【说站】excel筛选两列数据中的重复数据并排序

【说站】excel筛选两列数据中的重复数据并排序

如果靠人眼来一个个的对比excel的两列数据来去重的话,数据量少还能勉强对比一下,如果几千、几万条数据肯定就需要进行程式化处理,excel对于这个问题给我们提供了很方便的解决方案,这里主要用到exce...

【说站】Excel如何快速删除空行?WPS删除excel空白行

【说站】Excel如何快速删除空行?WPS删除excel空白行

站长我经常会处理excel文档,之前介绍过Microsoft Office excel文档删除空行的办法,今天介绍WPS Office下面的excel如何删除空白行。方法一:筛选  选中数据所在的那一...

【说站】判断服务器IP否被墙 是否被TCP阻断

【说站】判断服务器IP否被墙 是否被TCP阻断

现在国内很多购买国外主机服务器的,但往往很多主机商的机子用的人多了,国内使用者用这些服务器做啥的都有,正儿八经的做外贸其实没多大事情,但往往有些人就是不遵守法律法规,长此以往用的人多了,这些国外的主机...

【说站】删除WordPress页脚的 由WordPress强力驱动

【说站】删除WordPress页脚的 由WordPress强力驱动

所周知目前最新版的WordPress搭建的个人博客的2020主题(Twenty_Twenty)在网页的末端会有“由WordPress强力驱动”链接跳转字样,即WordPress的商业推广。作为网站搭建...