c#读写oracle 中文乱码问题解决

首先声明: 本文只能解决如下环境下的问题:

          Oracle 服务器字符集是:     SIMPLIFIED CHINESE_CHINA.WE8MSWIN1252;  客户端是一样的

        VS2010连接串     Data Source=mydb;Persist Security Info=True;User ID=;Password=;providerName="System.Data.OracleClient"

                 

      解决的办法很简单,就是是通过以下语句进行转换即可:

      读取时进行如下转换:

      return System.Text.Encoding.GetEncoding(936).GetString(System.Text.Encoding.GetEncoding(1252).GetBytes(o.ToString()));

     存储时采用如下转换:

     public static string ISO8859_GB2312(string read)
        {
            if (!string.IsNullOrEmpty(read))
            {
                System.Text.Encoding WIN1252 = System.Text.Encoding.GetEncoding(1252);
                System.Text.Encoding GB2312 = System.Text.Encoding.Default;
                byte[] iso = GB2312.GetBytes(read);
                return WIN1252.GetString(iso);
            }
            else
            {
                return string.Empty;
            }
        }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值