zoukankan      html  css  js  c++  java
  • 将datarow转换为实体的方法

    /// <summary>
            /// 将DataRow的值赋值到实体对象中.
            /// </summary>
            /// <typeparam name="T">实体对象烈性</typeparam>
            /// <param name="row">DataRow对象</param>
            /// <returns>赋值后的实体对象</returns>
            public static T ToEntity<T>(this DataRow row) where T : class, new()
            {
                if (row == null) return default(T);
                T result = new T();

                Type type = result.GetType();
                PropertyInfo[] properties = type.GetProperties();

                foreach (DataColumn column in row.Table.Columns)
                {
                    var tmpPropQuery = from item in properties
                                       where item.Name == column.ColumnName
                                       select item;
                    if (tmpPropQuery.Count() > 0)
                    {
                        PropertyInfo tmpProp = tmpPropQuery.FirstOrDefault();
                        if (tmpProp != null && tmpProp.CanWrite)
                        {
                            object o = row[column.ColumnName] != DBNull.Value && row[column.ColumnName] != null ?
                                row[column.ColumnName] : null;

                            object[] paras = { o };
                            tmpProp.ReflectedType.InvokeMember(tmpProp.Name, BindingFlags.SetProperty, null, result, paras);
                        }
                    }
                }

                return result;
            }

  • 相关阅读:
    var s=+newDate();
    sql2005+调用c#扩展
    fileAs访问拒绝and net后台打开服务器端文件和关闭服务器端文件
    js中的数组引用类型or值类型
    安装vfp9遇到的问题
    JQuery EasyUI TabPanel
    图标库
    SQL根据指定月份获取当前季度
    JQuery EasyUI DataGrid
    (int)、Int32.Parse()、Convert.ToInt32()类型区别
  • 原文地址:https://www.cnblogs.com/eryang/p/2563777.html
Copyright © 2011-2022 走看看