oracle数据库的中文乱码问题

应用换服务器重新部署,没想到以前运行得很正常的程序这次写入到oracle库的数据中文全是乱码,而导入的历史数据中文全部正常。

虽然操作系统是server 2008英文版,由于写到本地文件中日志的中文显示正常,开始怀疑是数据库的字符集设置问题,几番测试,发现不是,又怀疑是操作系统问题,重新装回中文版的server 2008,问题依旧。

只好打开VS调试,运行后就发现,从另一个Web service接到的XML字符串在VS中显示就是乱码,如下图:


后来请教高手,原来是在把这个内存中的XML串写入文件的时候没有指定编码格式,在程序中加下如下代码:

StreamWriter sw= newStreamWriter(fsasStream,System.Text.Encoding.GetEncoding("gb2312"));

再运行,VS中显示正常,接着写库,神奇地发现数据库中写入的字符串还是乱的。

SQL语句正常:


写库乱码:


再仔细从连接数据库的对象开始排查,最后终于通过对比发现,问题出在数据库连接串上,连接串上没有指定字符编码:Unicode=True,

stringconnStr = "Data Source=" +serverName +";User Id=" + user +";Password=" + pwd + ";Unicode=True"

不要小看这几个字,加上后,再测试,一切正常。所以连接串中的每个部分都有他的作用,只有在遇到问题了才会意识到他存在的意义。


总结:涉及到中文的问题,两点一定要注意:

1、XML读写文本文时,一定要加上编码方式:System.Text.Encoding.GetEncoding("gb2312")

2、Oracle数据库连接串中一定要加上Unicode=True

其实就是一定要注意编码格式。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值