您的位置:首页 > 数据库 > Oracle

oracle 插入汉字时字符编码问题

2011-04-15 19:35 190 查看
背景:

myeclipse 字符编码 GBK

oracle数据库字符编码 GBK

插入内容从第三方通过webservice接口取的,字符编码UTF-8



问题描述:

通过 java PreparedStatement 预编译进入插入操作,跑SQL异常,baidu字符编码问题,经过若干方法转码还是无果,最后变通解决



变通解决办法:

通过insert拼接sql语句,因为当前myeclipse环境为GBK编码,所以拼接后的insert中的汉字即默认转化为GBK编码,插入操作正常。

拼接SQL如下:

String sql = "insert into t_ivr_jobs_info_bak (JOBID, JOBTYPE, JOBAREA, JOBINFO) values ("+jobId+", '"+jobType+"', '"+jobCity+"', '"+jobInfo+"')";








总结

通过PreparedStatement.setString(index, str);应该是直接连接到数据库,这个过程中的str字符编码还是utf-8,如果不转化,直接 插入数据库跑异常,编码格式不一致。



通过上述拼接sql,在这个过程中由于变量已经显示在当前环境,这个过程默认转化为GBK格式的,所以再做插入就规避了编码不统一问题,

但是也没法使用绑定变量来提高性能,不过有时候性能并不是最重要的。



待验证..............
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: