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

  • 相关阅读:
    65 组件 静态文件相关 视图
    作者和书籍的增删改查 多对多
    64 装饰器函数: 母版 csrf防御机制 cookie
    61 书籍和出版社 的增删改查 几秒后跳转一个页面
    60 Django项目 单表(出版社)的增删改查 __str__方法及格式化输出 的两个方法
    模块 itertools
    59 Django基础三件套 , 模板{{}}语言 , 程序连mysql Django项目app Django中ORM的使用
    nginx 并发数
    设置tomcat最大内存
    goaccess安装
  • 原文地址:https://www.cnblogs.com/eryang/p/2563777.html
Copyright © 2011-2022 走看看