今天检验一个字符串长度时出现了问题。我在数据库(ORACLE)中定义的长度时VARCHAR2(50),
"附言字段测试1附言字段测试2附言字段测试3附言字段测试4",这是测试数据,一共52个字节,在插入到数据库中报错了,
但是在JAVA使用length()方法他的长度并没有超过50,但在我的需求中他是超出的。JAVA中文是一个字符,但和字节不是1。
public static int getStringLen(String str,String codeType){
int reLn=0;
if(str==null||str.equals("")){
return reLn;
}
try {
// byte[] t_iso = str.getBytes("ISO8859-1");
byte[] t_gbk = str.getBytes("GBK");
byte[] t_utf8 = str.getBytes("UTF-8");
// System.out.println("使用ISO解码..." + t_iso.length);
// System.out.println("使用GBK解码..." + t_gbk.length);
// System.out.println("使用UTF8解码..." + t_utf8.length);
if(codeType==null||codeType.equals("")){
return t_gbk.length;
}else if(codeType!=null&&codeType.equals("UTF-8")){
return t_utf8.length;
}
} catch (Exception e) {
}
return reLn;
}