>데이터 베이스 >MySQL 튜토리얼 >Oracle 插入汉字时字符编码问题

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

WBOY
WBOY원래의
2016-06-07 17:00:311198검색

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

背景:

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格式的,所以再做插入就规避了编码不统一问题,

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

    linux

  • 성명:
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.