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

本文描述了在MyEclipse环境下使用GBK编码与来自UTF-8编码的数据源发生冲突的问题,并提供了一种通过拼接SQL语句来解决编码不一致的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景:

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

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

 

待验证..............

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值