代码改变世界

用C#解决Oracle9i和Oracle10g字符集不兼容的问题

2008-07-08 14:59  马伟  阅读(848)  评论(0编辑  收藏  举报

      前段时间,我应公司派遣去云南给南方电网开发一个电力分析系统。因为我们的系统主要作用是统计计算和数据分析,所以本身并不采集基础数据,基础数据都是从别的第三方系统采集而来。还好的是大部分系统的数据采集都是通过WEB服务的方式,当时只有一家系统要求我们直接从他们的数据库里去读取(呵呵,这在电力部门一般是不被允许的,毕竟数据需要安全吗),大概是人家不愿意写接口吧。本来对于我们来说直接去数据库读取数据是最好不过了。但在这里问题出现了,采集的数据全部成了乱码,原因是字符集不相同。对方用的是Oracle9i数据库,字符集编码是WE8ISO8859P1。而我们用的是Oracle10g数据库,字符集编码是ZHS16GBK。由于权限的原因,我无法更改对方数据库字符集编码。我曾经尝试把我们的数据库修改成WE8ISO8859P1格式,但最后我们的数据库全部成了乱码。
    呵呵,看来修改字符集编码是不行的。我便给Oracle公司打电话咨询,漫长的等了一天,Oracle公司的回答是“很抱歉,只有一种方法可以解决,就是把对方的数据转换成txt”。晕!这是什么解决方案吗,我根本就没法用。。。。。。。。
    最好经过一半天的考虑,我决定使用程序来解决,既先把对方的数据转换成
GB2312格式,然后再进行采集。函数如下:
 
public static string ConverWE8ISO8859P1ToGB2312(string data)
  {
   return System.Text.Encoding.Default.GetString
   (System.Text.Encoding.GetEncoding("iso-88591").GetBytes(data));
  }

哈哈!经过一测试,问题解决了。