MySQL char 尾随空格丢失与右侧空格填充
2023-12-13 04:51:29
????????今天看《高性能MySQL(第四版)》,讲char,varchar时说“当存储CHAR值时,MySQL删除所有尾随空格。如果需要进行比较,值会用空格填充。”感觉这两句话有冲突啊,便研究了下。
? ? ? ? 对于具体的问题,当然官方文档是最好的,The CHAR and VARCHAR Types,推荐阅读全文。
????????原来并不是“如果需要进行比较”,而是因为是定长,会用空格填充。
????????那么就想到了一个问题,为什么要填充。为什么用空格填充。网上没找到相关资料,我试着回答下(就是猜的)
为什么填充:
????????以char(10)为例,这里的10指10个字符,char(10)到底占用多少磁盘空间,和字符集有关。因为是固定长度,已经分配了这么多空间。如果不填充,就会造成碎片问题,不连续。
为什么用空格填充:
????????char类型存储的是字符而不是字节。分配固定长度之后,空余部分肯定要存贮当前字符集中的某个字符,逻辑上讲用空格填充应该是最合适的。也不能用“00***00”,因为“00***00”在当前字符集中可能不是任何字符,即便是某个字符,也不如用空格表示更合理。
????????右侧用空格填充,那么原本右侧的空格和填充的空格就分不清了,就会有右侧空格丢失的问题。
固定长度有什么好处呢:
1、对于经常修改的数据,VARCHAR容易出现碎片(长变短),还可能有重建记录、页分裂的开销(短变长)。
2、对于非常短的列,CHAR也比VARCHAR更高效;设计为只保存Y和N的值的CHAR(1)在单字节字符集[插图]中只使用1字节,但VARCHAR(1)需要2字节,因为还有一个记录长度的额外字节。
?
文章来源:https://blog.csdn.net/yangguosheng/article/details/134894992
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!