麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

即使用ADO.NET,也要輕量級實體映射,比Dapper和Ormlite均快

2019-11-17 02:19:26
字體:
來源:轉載
供稿:網友

即使用ADO.NET,也要輕量級實體映射,比Dapper和Ormlite均快

不管出于什么原因,有時候框架人員摒棄了NH或EF,而使用原生數據庫訪問對象。

為了優美的編程,用上我寫的輕量級映射擴展方法吧

目的:將SqlDataReader自動轉換成T類型

代碼如下:

    /// <summary>    /// 提供將SqlDataReader轉成T類型的擴展方法    /// </summary>    public static class SqlDataReaderEx    {        PRivate static object _obj = new object();        /// <summary>        /// 屬性反射信息緩存 key:類型的hashCode,value屬性信息        /// </summary>        private static Dictionary<int, Dictionary<string, PropertyInfo>> propInfoCache = new Dictionary<int, Dictionary<string, PropertyInfo>>();        /// <summary>        /// 將SqlDataReader轉成T類型        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="reader"></param>        /// <returns></returns>        public static T To<T>(this SqlDataReader reader)          where T : new()        {            if (reader == null || reader.HasRows == false) return default(T);            var res = new T();            var propInfos = GetFieldnameFromCache<T>();            for (int i = 0; i < reader.FieldCount; i++)            {                var n = reader.GetName(i).ToLower();                if (propInfos.ContainsKey(n))                {                    PropertyInfo prop = propInfos[n];                    var IsValueType = prop.PropertyType.IsValueType;                    object defaultValue = null;//引用類型或可空值類型的默認值                    if (IsValueType) {                        if ((!prop.PropertyType.IsGenericType)                            ||(prop.PropertyType.IsGenericType&&!prop.PropertyType.GetGenericTypeDefinition().Equals(typeof(Nullable<>))))                        {                            defaultValue = 0;//非空值類型的默認值                        }                    }                    var v = reader.GetValue(i);                    prop.SetValue(res, (Convert.IsDBNull(v) ? defaultValue : v), null);                }            }            return res;        }        private static Dictionary<string, PropertyInfo> GetFieldnameFromCache<T>()        {            Dictionary<string, PropertyInfo> res = null;            var hashCode = typeof(T).GetHashCode();            var filedNames = GetFieldname<T>();            lock (_obj)            {                if (!propInfoCache.ContainsKey(hashCode))                {                    propInfoCache.Add(hashCode, filedNames);                }            }            res = propInfoCache[hashCode];            return res;        }        /// <summary>        /// 獲取一個類型的對應數據表的字段信息        /// </summary>        /// <typeparam name="T"></typeparam>        /// <returns></returns>        private static Dictionary<string, PropertyInfo> GetFieldname<T>()        {            var res = new Dictionary<string, PropertyInfo>();            var props = typeof(T).GetProperties();            foreach (PropertyInfo item in props)            {                                res.Add(item.GetFieldName(), item);            }            return res;        }             /// <summary>        /// 將SqlDataReader轉成List<T>類型        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="reader"></param>        /// <returns></returns>        public static List<T> ToList<T>(this SqlDataReader reader)            where T : new()        {            if (reader == null || reader.HasRows == false) return null;            var res = new List<T>();            while (reader.Read())            {                res.Add(reader.To<T>());            }            return res;        }                  /// <summary>        /// 獲取該屬性對應到數據表中的字段名稱        /// </summary>        /// <param name="propInfo"></param>        /// <returns></returns>        public static string GetFieldName(this PropertyInfo propInfo)        {            var fieldname = propInfo.Name;            var attr = propInfo.GetCustomAttributes(false);            foreach (var a in attr)            {                if (a is DataFieldAttribute)                {                    fieldname = (a as DataFieldAttribute).Name;                    break;                }            }            return fieldname.ToLower();        }    }

在項目中再也需要reader["fieldname"]這樣的惹人厭的寫法了

換言之,只需要這樣寫:

 Model model=SqlDataReader.To<Model>(); 

基本原理當然少不了反射,實體的屬性可以用DataField特性標記在數據表中的字段名稱,否則與屬性同名,字段名稱不區分大小寫。

DataField特性是自己寫的,只有一個Name屬性。

    public class DataFieldAttribute : Attribute    {        public DataFieldAttribute()        {        }        public DataFieldAttribute(string name)        {            m_name = name;        }        private string m_name = null;        public string Name { get { return m_name; } set { m_name = value; } }    }

是不是很方便,雖然重復造輪子了,但是即使用了原生數據庫訪問對象,又輕松了轉換了實體,帶來的方便性可以彌補一切。

記得點【推薦】

性能測試:

與OrmLite對比:

從圖中看出,在測試1000次的時候,本文的擴展方法比OrmLite的方法快1263ms,測試多次效率均與該結果基本相符。

Test測試源碼如下:


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日韩黄在线 | 美女亚洲 | 日本黄色a视频 | 一区二区三区视频在线观看 | 免费a级黄色片 | 一级大片久久 | 国产精品av久久久久久网址 | 美女擦逼 | 久久人人爽人人爽人人片av高清 | 精品一区二区久久久久久久网精 | 国产成年人在线观看 | 国产美女视频免费 | 国产一区二区三区四区五区加勒比 | 久久久成人一区二区免费影院 | 成年性羞羞视频免费观看无限 | 久久精品一区二区三区四区五区 | 中文字幕专区高清在线观看 | 午夜精品福利视频 | 在线观看中文字幕av | 99影视在线视频免费观看 | 一级黄色欧美 | 久久国产免费视频 | 四虎久草| 牛牛a级毛片在线播放 | 日本黄色一级电影 | 国产亚洲精品网站 | 日本在线视频免费观看 | 国产成人高潮免费观看精品 | 成人免费毛片一 | 国内精品久久久久影院不卡 | 亚洲精品 在线播放 | 一级做受大片免费视频 | 视频一区 中文字幕 | 日产精品一区二区三区在线观看 | 99麻豆久久久国产精品免费 | 国产日产精品久久久久快鸭 | 中国免费一级毛片 | 日本中文一级片 | 9999久久 | 高清国产福利 | 7777视频|