zoukankan      html  css  js  c++  java
  • .NET C# 泛型集合转DataTable

    1.功能类

    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;

    namespace Infrastructure
    {
        public static class EnumerableExtensions
        {
            public static DataTable CopyToDataTable<T>(this IEnumerable<T> array)
            {
                DataTable result = new DataTable();
                foreach (PropertyDescriptor pd in TypeDescriptor.GetProperties(typeof (T)))
                {
                    if (pd.PropertyType.IsGenericType && pd.PropertyType.GetGenericTypeDefinition().Equals(typeof (Nullable<>)))
                        result.Columns.Add(pd.Name,Nullable.GetUnderlyingType(pd.PropertyType));
                    else
                        result.Columns.Add(pd.Name, pd.PropertyType);
                }
                foreach (T item in array)
                {
                    DataRow row = result.NewRow();
                    foreach (PropertyDescriptor pd in TypeDescriptor.GetProperties(typeof(T)))
                        row[pd.Name] = pd.GetValue(item) ?? DBNull.Value;
                    result.Rows.Add(row);
                }
                return result;
            }
        }
    }
    2.调用方式

    List<T> items = new List<T>();

    xxx //为items赋值

    DataTable dataTable = EnumerableExtensions.CopyToDataTable(items);//调用方法

  • 相关阅读:
    Geogebra指令
    大表修改表结构
    mongodb获取配置参数getParameter
    mysql的binlog增量日志解析,提供增量数据订阅和消费
    chaosblade-exec-os项目的burnio.go文件解读
    mysql的where条件中的字段不要加函数
    mysql释放大表空间的正确之道
    mysql服务器问题
    purge binary logs to 'mysql-bin.039790';
    golang操作mysql数据库的规范
  • 原文地址:https://www.cnblogs.com/jeff151013/p/11739359.html
Copyright © 2011-2022 走看看