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;
            }

  • 相关阅读:
    Dao层
    I/O流
    导入第三方jar包
    怎么使用log4j
    JDBC访问数据库的步骤
    抽象和封装
    JDBC中PreparedStatement接口提供的execute、executeQuery和executeUpdate之间的区别及用法
    ResultSet next方法
    实体类(entity)的作用
    接口的作用
  • 原文地址:https://www.cnblogs.com/eryang/p/2563777.html
Copyright © 2011-2022 走看看