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如下:
总结
通过PreparedStatement.setString(index, str);应该是直接连接到数据库,这个过程中的str字符编码还是utf-8,如果不转化,直接 插入数据库跑异常,编码格式不一致。
通过上述拼接sql,在这个过程中由于变量已经显示在当前环境,这个过程默认转化为GBK格式的,所以再做插入就规避了编码不统一问题,
但是也没法使用绑定变量来提高性能,不过有时候性能并不是最重要的。
待验证..............
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格式的,所以再做插入就规避了编码不统一问题,
但是也没法使用绑定变量来提高性能,不过有时候性能并不是最重要的。
待验证..............
相关文章推荐
- Linux下Oracle字符集问题引发的汉字插入失败解决方案
- PLSQL Developer 插入中文 乱码问题,如图 这个是由于oracle服务器端字符编码 和 Oracle 客户端 字符编码不一致引起的。 检查Oracle服务器端字符编码,用 sel
- 关于用php插入汉字到oracle中出现不乱码问题
- CodeIgniter 向mysql插入数据包括字母、汉字问题
- oracle insert &字符插入问题
- JDBC读取Oracle的US7ASCII编码中文乱码及不同编码下汉字占用字节的问题
- Oracle插入日期数据常见的2个问题和解决方法
- CodeIgniter 向mysql插入数据包含字母、汉字问题
- 解决ORACLE插入乱码的问题
- Mysql中插入汉字出现乱码问题
- 再次明确Oracle插入与读取的顺序问题
- 解决Oracle中字符集导致一个汉字占用3个字节的问题
- mybatis批量插入oracle大量数据记录性能问题解决
- oracle导入半个汉字的问题
- Oracle汉字乱码问题原因及解决方法
- MySQL插入显示汉字出现乱码问题的解决
- oracle改变字符编码(ORA-12899问题)
- 影响ORACLE汉字显示的字符集问题
- oracle 问题-ORA-14400: 插入的分区关键字未映射到任何分区
- oracle中的varchar2存放汉字的问题总结