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


          前段时间,我应公司派遣去云南给南方电网开发一个电力分析系统。因为我们的系统主要作用是统计计算和数据分析,所以本身并不采集基础数据,基础数据都是从别的第三方系统采集而来。还好的是大部分系统的数据采集都是通过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));
      }

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

  • 相关阅读:
    怎样简单编写一个html网页
    C# 委托实现冒泡排序
    C# 运算符
    EF 多表联查方法
    Log4net 配置文件
    vs调试 iis发布之后的项目
    继承 ,构造方法使用
    C#扩展方法
    partial 部分类
    WeakReference 弱引用
  • 原文地址:https://www.cnblogs.com/madengwei/p/1238193.html
Copyright © 2020-2023  润新知