在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个字节。
在Java中可以使用以下方式取得string的长度:
private
int
getLength(NcsTextField t)
{
try {
int iLength = new String(t.getText().getBytes("UTF8"),"iso-8859-1").length();
return iLength;
} catch (Exception e) {
return t.getText().length();
}
}
这样取得的一个汉字占3个字节,
try {
int iLength = new String(t.getText().getBytes("UTF8"),"iso-8859-1").length();
return iLength;
} catch (Exception e) {
return t.getText().length();
}
}
如果把UTF8换成GB2312则一个汉字占2个字节
本文转自永春博客园博客,原文链接:http://www.cnblogs.com/firstyi/archive/2007/09/18/897542.html,如需转载请自行联系原作者