[转]中文字符不一定都是占2个字节 Oracle

本文解释了在Oracle数据库中,字段类型varchar2的实际长度如何受到数据库字符集配置的影响。通过查询v$nls_parameters视图可以得知当前数据库的字符集,从而确定一个中文字符占用的字节数。

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

在Oracle中,经常把字段的类型设置成varchar2。

以前都是认为每一个中文字符都是占用2个字节,即varchar2(30)只能存放15个中文或30个英文。

今天偶然发现,这个其实和Oracle的配置是相关的,用以下语句查询:
   select * from v$nls_parameters t where t.PARAMETER='NLS_CHARACTERSET';
可以查询到当前数据库的字符集,如果value=GB2312,那么一个汉字占用2个字节,如果value=AL32UTF8,那么一个汉字占用3个字节。


string uda = "adsafsdgdsfhdgkjlkyriuuyuiouipip收复失地饭是钢对符合法规和结果返回结果好看开了的复合肥各家各户客户经理发给";
        Response.Write("sdsf: "+uda.Length+" tttttttt:"+uda.ToCharArray().Length);
     //   adsafsdgdsfhdgkjlkyriuuyuiouipip收复失地饭是钢对符合法规和结果返回结果好看开了的复合肥各家各户客户经理发给
       // char[] b = uda.ToCharArray;
        byte[] sarr = System.Text.Encoding.Default.GetBytes(uda);
        Response.Write("<br/> ggg:"+sarr.Length);

        Response.Write("<br>sff:"+uda);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值