如何将LINQ结果转换为DATATABLE?

Kis*_*mar 3 c# linq datatable

有没有办法将LINQ表达式的结果转换为a DataTable而不单步执行每个元素?

Sha*_*ica 5

相信这位博客,但我在这里改进了他的算法.让自己成为一种扩展方法:

    public static DataTable ToADOTable<T>(this IEnumerable<T> varlist)
    {
        DataTable dtReturn = new DataTable();
        // Use reflection to get property names, to create table
        // column names
        PropertyInfo[] oProps = typeof(T).GetProperties();
        foreach (PropertyInfo pi in oProps)
        {
            Type colType = pi.PropertyType; 
            if ((colType.IsGenericType) && (colType.GetGenericTypeDefinition() == typeof(Nullable<>)))
                colType = colType.GetGenericArguments()[0];
            dtReturn.Columns.Add(new DataColumn(pi.Name, colType));
        }
        foreach (T rec in varlist)
        {
            DataRow dr = dtReturn.NewRow();
            foreach (PropertyInfo pi in oProps)
                dr[pi.Name] = pi.GetValue(rec, null) == null ? DBNull.Value : pi.GetValue(rec, null);
            dtReturn.Rows.Add(dr);
        }

        return (dtReturn);
    }
Run Code Online (Sandbox Code Playgroud)

用法:

DataTable dt = query.ToADOTable();
Run Code Online (Sandbox Code Playgroud)