c#.net进行odbc连接sybase中文乱码问题

网上找了许久大多数都是去改变sybase的服务器字符集去解决些问题,可公司的sybase数据库是别的pb程序用的,不能改的,新的程序只是想查询一下数据所以只有进行字符集转换了
None.gif SELECT  PROPERTY(  ' CharSet '  )
得到字符集cp936,转换如下
None.gif Byte[] mybyte  =  System.Text.Encoding.GetEncoding(936).GetBytes( " 乱码字符串 " .ToCharArray());
None.gif
得到结果还是乱码,想了很久也没明白,看来只能暴力一下了
 StringBuilder pname  =   new  StringBuilder();
  
foreach  (EncodingInfo ei  in  Encoding.GetEncodings())
 {
          Byte[] mybyte 
=  System.Text.Encoding.GetEncoding(ei.CodePage).GetBytes(("乱码字符串".ToCharArray());
           pname.Append(ei.Name 
+   " ( "   +  ei.CodePage  +   " ): "   +  System.Text.Encoding.GetEncoding( " gb2312 " ).GetString(mybyte,  0 , mybyte.Length)  +   " \r\n " );
      }
 MessageBox.Show(pname.ToString());
得到ibm850(850)与ibm858(858)可以正常显示中文,问题解决,为什么是850与858也不知道有没有朋友知道.

转载于:https://www.cnblogs.com/ark/archive/2008/06/04/1213324.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值