mysql数据库中varchar()这个括号里的数字所代表的的储存长度,以及Oracle中char()括号中的长度

本文详细解释了在不同数据库版本中,如4.0及以下版本和5.0及以上版本,以及Oracle XE中,'varchar'和'char'类型在处理字符(如UTF8汉字)时的区别。在4.0版本及以下,'varchar(3)'表示3字节,只能存储一个UTF8汉字;而在5.0版本及以上,表示3字符,可以存储三个字符,无论是数字、字母还是UTF8汉字。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这个括号里面的数字其实和版本有关:

4.0版本及以下,varchar(3),指的是3字节,如果存放UTF8汉字时,只能存1个(每个汉字3字节).

5.0版本及以上,varchar(3),指的是3字符,无论存放的是数字、字母还是UTF8汉字,都可以存放3个.

一个是字节一个是字符,两者并不相同.

在我现在用的Oracle XE版本里面的char(3),指的是3字节,如果存放UTF8汉字时,只能存1个(每个汉字3字节).

如果是char(2),那么就只能存不到一个汉字,会报异常,说的就是你所给予的最大长度为2,但是你填了一个长度为3的字

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值