在Oracle中添加的中文变成"靠靠靠..."

2 篇文章 0 订阅

如果安装的ORACLE字符集为非中文字符集(例如WE8ISO8859P1),使用System.Data.OracleClient作为驱动插入的中文字符串会全部变成“靠靠靠”之类的怪串(两个汉字一个字符串),可以使用如下两种解决方案:

1、使用System.Data.OleDb作为数据驱动,其连接字符串格式如下所示:

Provider=MSDAORA.1; Data Source=服务名; User Id=用户名; Password=口令; conn.cursorlocation=3

2、重新编码字符串

public string GetOracleCh(string str)  
{
  	Encoding gbk_encoder = Encoding.GetEncoding(936);	//GBK  
	byte[] bs = gbk_encoder.GetBytes(str);
  	char[] cs = new char[bs.Length];
  	for (int i = 0; i < bs.Length; i++)
  		cs[i] = Convert.ToChar(bs[i]);
  	return new String(cs); 
}
同时也出现了对应的问题,那就是使用常规手段从数据库出中取出的字符串是乱码,同样使用上面的两种解决方案,第二种解决方案对应的代码如下所示:

 

public string GetChString(string str)  
{
  	byte[] bs = new byte[str.Length];
  	for (int i = 0; i < str.Length; i++)
  		bs[i] = Convert.ToByte(str[i]);
  	Encoding gbk_encoder = Encoding.GetEncoding(936);
  	return gbk_encoder.GetString(bs); 
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值