madengwei2008

To the end of the sea, the shore is the sky; up the top of the mountain, the peak is me.

  博客园 :: 首页 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  9 随笔 :: 0 文章 :: 8 评论 :: 0 Trackbacks

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

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

posted on 2008-07-08 14:59 马伟 阅读(140) 评论(0)  编辑 收藏 所属分类: c#asp.net.net2008

标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交