在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);