数据库:char , varchar 和varchar2的使用区别

本文探讨了数据库中char、varchar和varchar2三种数据类型的使用区别。char是定长,存储效率高但浪费空间,适合存储短信息和确定长度的字段,频繁更改的列。varchar是变长,节省空间但查询效率较低,适用于长度不固定的字段。varchar2是Oracle特有的,处理空字符串方式与varchar不同,移植性不如varchar。
摘要由CSDN通过智能技术生成

1.定长和不定长

①char(M) 类型,每个值都占用 M 个字符,如果某个值小于M,mysql就会在它的右边用空格补足,在检索操作中,那些补足的空格将被去掉;

②varchar(M) 类型,每个值刚好占用够用的字节,再加上一个用来记录其长度的字节(即总长度为L+1字节)

2.存储效率比较

对计算机来说,char是定长的,处理的时候,只需要将右边的空格去掉即可,

而 varchar ,最后一个字符还是记录的字符长度,计算机处理的时候,还要计算最后这个字符,所以有额外的计算

相比较之下,char的存储效率比varchar要高;

 

我们可以看到char类型在存放数据的时候,中间是没有间隔的,数据本身是有空格的,但是数据段之间没有间隔,因为我们在创建列的时候已经告诉MySQL列的长度了&#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值