resin+apache+mysql+linux中文问题,救命,多谢了! resin支持中文,看看你在数据库联接时有没有重新设置编码 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 JDK1.2的中文问题主要是由于引入了Unicode引起的(其实在1.1版本中就有了),U nicode的字符由16bit构成,关于Unicode更详细的信息有兴趣者可以到www.unico de.org查阅,在1.0版本中,一个中文是由两个char(8bit)组成的,而1.1以上版本中 是由一个char(16bit)组成的.这一点大家可以用System.out.println(s.length( ))语句来证实,其中s为中文字串. 现在来说说解决办法,首先声明这些结果只是在我的环境里测试通过,如果在各位 的环境里有问题,请务必告知. 我的环境是JDK1.2+Win95+Sybase JDBC Driver(PowerJ2.5附带)+Oracle JDBC D river(Oracle8.0.3附带). 我的第一个体会是用JDBC-ODBC桥接访问数据库中文输入有问题,我还没解决,我用 的JDBCODBC Driver是JDK1.2自带的. 第二个体会是用JDBC直接联数据库,这时可能有两种情况: 1,中文输入没问题(Oracle8),即可以在SQL语句中直接写中文,如: statement.executeUpdate("inser into tablename values("测试",....) 2,中文输入有问题(Sybase11),看错误可知是Unicode转换引起的,解决办法是将U nicode转换为ASCII形式,即一个汉字拆成两个char,用到两个类ByteToCharConve rter和CharToByteConverter,在sun.io.*中,可以在JDK home\jre\lib\i18n.jar 中找到,没有文档,我也实在网上找到用法的. 在输入时,用ChineseStringToAscii转换为ASCII码字串,查询时用AsciiToChines eString转换为Unicode字串.源代码如下: public static String AsciiToChineseString(String s) { char[] orig = s.toCharArray(); byte[] dest = new byte[orig.length]; for (int i=0;i<orig.length;i++) dest[i] = (byte)(orig[i]&0xFF); try { ByteToCharConverter toChar = ByteToCharConverter.getConverter("g b2312"); return new String(toChar.convertAll(dest)); } catch (Exception e) { System.out.println(e); return s; } } public static String ChineseStringToAscii(String s) { try { CharToByteConverter toByte = CharToByteConverter.getConverter("g b2312"); byte[] orig = toByte.convertAll(s.toCharArray()); char[] dest = new char[orig.length]; for (int i=0;i<orig.length;i++) dest[i] = (char)(orig[i] & 0xFF); return new String(dest); } catch (Exception e) { System.out.println(e); return s; } } 主程序片断如下: try{ Statement stmt; Class.forName("com.sybase.jdbc.SybDriver"); Connection conn =DriverManager.getConnection ("jdbc:sybase:Tds:202.9 7.228.249:5000/todo","sa",""); stmt = conn.createStatement (); String s="何海涛"; s=ChineseStringToAscii(s); stmt.executeUpdate ("insert into russia values('"+s+"',1,1,'"+s+ "')"); }catch(Exception e){ System.out.println(e); } 在读数据时用String s=AsciiToChineseString(rs.getString(1)) -------------------- 因为手头只能对这两种数据库进行测试,所以对别的数据库可能出现的情况不能保 证.不过我估计基本是上面这两种情况.另外,用JDK1.2有的公司提供的Driver也升 级了,比如Sybase原来的Driver就不好使.原理就是这样,在实际操作中要靠自己摸 索了.上面两个方法参考了台湾某BBS的一篇文章. 你看看吧 也许有帮助 使用toad schema 里面有表aaa sql editor里面却查不到 为什么从内部类中访问局部变量需要被声明为最终类型 求教JAVA初级高级编程练习题 !!!调用yahoo的搜索API!! IE中可以查询 ------附源码 有关classpath的问题 100分找一款手机!大家给点意见!谢谢! 小菜鸟碰到大难题。晚上揭贴。 JB8出问题,请大家救命(在线等) 一个关于垃圾回收站的问题 我jbuilder 6.0安装好后,运行程序无反应,等一会出现提示错误为‘unkown licence file format',然后就没了 关于内部类的问题! 很简单的问题,快来拿分
nicode的字符由16bit构成,关于Unicode更详细的信息有兴趣者可以到www.unico
de.org查阅,在1.0版本中,一个中文是由两个char(8bit)组成的,而1.1以上版本中
是由一个char(16bit)组成的.这一点大家可以用System.out.println(s.length(
))语句来证实,其中s为中文字串.
现在来说说解决办法,首先声明这些结果只是在我的环境里测试通过,如果在各位
的环境里有问题,请务必告知.
我的环境是JDK1.2+Win95+Sybase JDBC Driver(PowerJ2.5附带)+Oracle JDBC D
river(Oracle8.0.3附带).
我的第一个体会是用JDBC-ODBC桥接访问数据库中文输入有问题,我还没解决,我用
的JDBCODBC Driver是JDK1.2自带的.
第二个体会是用JDBC直接联数据库,这时可能有两种情况:
1,中文输入没问题(Oracle8),即可以在SQL语句中直接写中文,如:
statement.executeUpdate("inser into tablename values("测试",....)
2,中文输入有问题(Sybase11),看错误可知是Unicode转换引起的,解决办法是将U
nicode转换为ASCII形式,即一个汉字拆成两个char,用到两个类ByteToCharConve
rter和CharToByteConverter,在sun.io.*中,可以在JDK home\jre\lib\i18n.jar
中找到,没有文档,我也实在网上找到用法的.
在输入时,用ChineseStringToAscii转换为ASCII码字串,查询时用AsciiToChines
eString转换为Unicode字串.源代码如下:
public static String AsciiToChineseString(String s) {
char[] orig = s.toCharArray();
byte[] dest = new byte[orig.length];
for (int i=0;i<orig.length;i++)
dest[i] = (byte)(orig[i]&0xFF);
try {
ByteToCharConverter toChar = ByteToCharConverter.getConverter("g
b2312");
return new String(toChar.convertAll(dest));
}
catch (Exception e) {
System.out.println(e);
return s;
}
} public static String ChineseStringToAscii(String s) {
try {
CharToByteConverter toByte = CharToByteConverter.getConverter("g
b2312");
byte[] orig = toByte.convertAll(s.toCharArray());
char[] dest = new char[orig.length];
for (int i=0;i<orig.length;i++)
dest[i] = (char)(orig[i] & 0xFF);
return new String(dest);
}
catch (Exception e) {
System.out.println(e);
return s;
}
}
主程序片断如下:
try{
Statement stmt;
Class.forName("com.sybase.jdbc.SybDriver");
Connection conn =DriverManager.getConnection ("jdbc:sybase:Tds:202.9
7.228.249:5000/todo","sa","");
stmt = conn.createStatement ();
String s="何海涛";
s=ChineseStringToAscii(s);
stmt.executeUpdate ("insert into russia values('"+s+"',1,1,'"+s+
"')");
}catch(Exception e){
System.out.println(e);
}
在读数据时用String s=AsciiToChineseString(rs.getString(1))
--------------------
因为手头只能对这两种数据库进行测试,所以对别的数据库可能出现的情况不能保
证.不过我估计基本是上面这两种情况.另外,用JDK1.2有的公司提供的Driver也升
级了,比如Sybase原来的Driver就不好使.原理就是这样,在实际操作中要靠自己摸
索了.上面两个方法参考了台湾某BBS的一篇文章. 你看看吧 也许有帮助