swing的table里的中文数据为乱码。

lyszjs 2006-10-12 09:52:07
数据库里查询出来的中文在 table里显示成乱码,怎么解决。
...全文
264 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
lyszjs 2006-10-12
  • 打赏
  • 举报
回复
如:String tmp = rs.getString(1);
tmp = new String(tmp.getBytes("iso-8859-1"), "gb2312");
试过,不行。
--------------
stmt.execute("set names 'gbk'");
也不行。
--------------------
调试的时候,发现 tmp = new String(tmp.getBytes("iso-8859-1"), "gb2312")已经是乱码了;但在mysql的客户端执行sql语句则 会正常显示。
wuv1982 2006-10-12
  • 打赏
  • 举报
回复
如果是jdbc的话,stmt.execute("set names 'gbk'");
具体jdbc的语法不记得了,就是在select之前多执行一条不需要返回值的sql语句
lyszjs 2006-10-12
  • 打赏
  • 举报
回复
让数据库在查询或者插入语句前面先执行下面的语句
set names 'gbk'
-----------------
怎么用,例如执行一个sql: select * from table.
set names 'gbk'怎么放。
wuv1982 2006-10-12
  • 打赏
  • 举报
回复
如果系统是中文windows的话
让数据库在查询或者插入语句前面先执行下面的语句
set names 'gbk'
shengli_liao 2006-10-12
  • 打赏
  • 举报
回复
一样呀
如:String tmp = rs.getString(1);
tmp = new String(tmp.getBytes("iso-8859-1"), "gb2312");
lyszjs 2006-10-12
  • 打赏
  • 举报
回复
用的是mysql,怎么转换。
shengli_liao 2006-10-12
  • 打赏
  • 举报
回复
注意字符转换,如果你用的数据库为SQLServer,千万记得转换:
return new String(str.getBytes("iso-8859-1"), "gb2312");
lyszjs 2006-10-12
  • 打赏
  • 举报
回复
ding

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧