ADO.NET 总结(2)

来源:未知 责任编辑:责任编辑 发表时间:2014-01-06 18:19 点击:

开始 –> 所有程序 –> Microsoft SQL Server 2005 –> Configuration Tools –> SQL Server configuration Manager –> 重启数据库服务.
四、使用MySql中文乱码问题
1、修改my.ini
[mysqld] default-character-set=utf8
2、没有权限修改my.ini
假设数据库采用了默认编码latin1,经研究发现:
1.    Select出的数据需要将其从拉丁文转化为GBK
2.    传入的SQL语句需要将其从GBK转化为拉丁文
public static class DBHelper { public static T Get<T>(DbDataRecord record,string field) { int num = record.GetOrdinal(field); if(record.IsDBNull(num)) return default(T); return (T)record[num]; } publicstatic int? ToInt32(object value) { if (value == null) return null; return((IConvertible)value).ToInt32(null); } public static voidAddParameter(string name, object value, DbCommand cmd) { DbParameter para =cmd.CreateParameter(); para.ParameterName =string.Format(ParameterMarkerFormat, name); if (value == null) para.Value =DBNull.Value; else para.Value = value; cmd.Parameters.Add(para); } publicstatic String LatinToGBK(String str) { try { byte[] bytesStr =Encoding.GetEncoding("latin1").GetBytes(str); returnEncoding.GetEncoding("GB2312").GetString(bytesStr); } catch { return str; }} public static String GBKToLatin(String str) { try { byte[] bytesStr =Encoding.GetEncoding("GB2312").GetBytes(str); returnEncoding.GetEncoding("latin1").GetString(bytesStr); } catch { return str; }} public static string ParameterMarkerFormat =DbProviderFactoryEx.SqlServerParameterMarkerFormat; }
应用
// 处理DbDataReader using (DbDataReader reader = cmd.ExecuteReader()) {foreach (DbDataRecord record in reader) { role.ID = DBHelper.Get<uint>(record, "ID"); role.Name = DBHelper.LatinToGBK(DBHelper.Get<string>(record, "RoleName")); role.Account =DBHelper.LatinToGBK(DBHelper.Get<string>(record, "Account")); return true;} } // 处理DataTable foreach (DataRow row in table.Rows) {row["OperationType"] =DBHelper.LatinToGBK(row["OperationType"].ToString());row["OperationReason"] =DBHelper.LatinToGBK(row["OperationReason"].ToString()); } // 传入的SQL语句DbCommand cmd = conn.CreateCommand(); cmd.CommandText = "select * from role where rolename=?rolename"; DBHelper.AddParameter("rolename",DBHelper.GBK2Latin(name), cmd);
  


作者 CppExample.com
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • 浅析.NET下XML数据访问新机制
  • asp.net 面试+笔试题目第1/2页
  • C# 邮件地址是否合法的验证
  • asp.net 设置GridView的选中行的实现代码
  • C#高级编程:数据库连接[1]
  • 经典C++程序1
  • IIS 自动回收导致后台定时器失效的问题解决
  • ASP.NET&#160;GridView列表代码示例
  • Asp.net MVC源码分析--Action Filter的链式调用
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1