zoukankan      html  css  js  c++  java
  • 用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));
      }

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

  • 相关阅读:
    bzoj4518[Sdoi2016]征途 斜率优化dp
    bzoj3675[Apio2014]序列分割 斜率优化dp
    bzoj3437小P的牧场 斜率优化dp
    bzoj3156防御准备 斜率优化dp
    bzoj1911[Apio2010]特别行动队 斜率优化dp
    bzoj5100 [POI2018]Plan metra 构造
    bzoj1597[Usaco2008 Mar]土地购买 斜率优化dp
    刷题总结——Middle number(ssoj 优先队列)
    刷题总结——doing homework again(hdu1789)
    NOIP2017赛前模拟(3):总结
  • 原文地址:https://www.cnblogs.com/madengwei/p/1238193.html
Copyright © 2011-2022 走看看