C#将LINQ数据集转换为Datatable

1.方法一:(测试可用)

//通过一个公共类将LINQ数据集转换为datatable

public DataTable LINQToDataTable<T>(IEnumerable<T> varlist)

{
     DataTable dtReturn = new DataTable();
     // column names 
     PropertyInfo[] oProps = null;

if (varlist == null) return dtReturn;

foreach (T rec in varlist)
     {
          // Use reflection to get property names, to create table, Only first time, others 
          will follow 
          if (oProps == null)
          {
               oProps = ((Type)rec.GetType()).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));
               }
          }

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

调用:

var vrCountry = from country in objEmpDataContext.CountryMaster
                        select new {country.CountryID,country.CountryName};

DataTable dt = LINQToDataTable(vrCountry);

2.方法二:(未测试)

public DataTable ToDataTable(System.Data.Linq.DataContext ctx, object query)
{
     if (query == null)
     {
          throw new ArgumentNullException("query");
     }
     
     IDbCommand cmd = ctx.GetCommand(query as IQueryable);
     SqlDataAdapter adapter = new SqlDataAdapter();
     adapter.SelectCommand = (SqlCommand)cmd;
     DataTable dt = new DataTable("sd");

try
     {
          cmd.Connection.Open();
          adapter.FillSchema(dt, SchemaType.Source); 
          adapter.Fill(dt);
     }
     finally
     {
          cmd.Connection.Close();
     }
     return dt;
}

调用:

var vrCountry = from country in objEmpDataContext.CountryMaster
                        select new {country.CountryID,country.CountryName};

DataTable dt = LINQToDataTable(objEmpDataContext,vrCountry);

原文地址:http://www.c-sharpcorner.com/uploadfile/VIMAL.LAKHERA/convert-a-linq-query-resultset-to-a-datatable/

转载于:https://blog.51cto.com/970076933/1941691

C#将LINQ数据集转换为Datatable相关推荐

  1. ListT转换为DataTable

    关于List<T>转换为DataTable的问题一直是开发过程中经常用到的,现从网上整理几个常用的转换方式,留作备用. (尊重作者原创,本文代码转发自 List 与 DataTable 转 ...

  2. 把ListT转换为DataTable

    下面这个学习,把List<T>转换为Datatable. 下面先创建一个对象T: class Ay{private int _ID;public int ID{get { return _ ...

  3. python将scikit-learn自带数据集转换为pandas dataframe格式

    python将scikit-learn自带数据集转换为pandas dataframe格式 目录 python将scikit-learn自带数据集转换为pandas dataframe格式 #仿真数据

  4. 将DataRow转换为DataTable

    /// <summary>/// DataRow转换为DataTable/// </summary>/// <param name="dt">& ...

  5. 将数据集转换为Excel格式的一个实现

    { 将数据集转换为Excel格式的一个实现 在做项目时,很多情况下,客户需要对我们保存在数据库中的数据再加工再利用, 如财务需要一份今年财务情况的电子报表,总经理需要今年销售情况的一个电子报表. 我们 ...

  6. C# 数组转换为DataTable 的三个方法

    using System; using System.Data; namespace ArrayToDataTable { class ArrayToDataTable { /// <summa ...

  7. SqlDataReader转换为DataTable

    SqlDataReader转换为DataTable 作者:未知 时间: 2007-6-11 13:05:56 文档类型:未知 来自:未知 浏览统计:37   代码一:    private void  ...

  8. Pytorch机器学习(三)——VOC数据集转换为YOLO数据集

    Pytorch机器学习(三)--VOC数据集转换为YOLO数据集 目录 Pytorch机器学习(三)--VOC数据集转换为YOLO数据集 前言 一.yolo格式 二.代码 总结 前言 本文为利用pyt ...

  9. 将cityscapes数据集转换为19类 convert cityscapes to 19 categories

    在用DANet网络时候,Readme里面提到了处理数据集时,提到了要把cityscapes数据集转换为19类: Download the Cityscapes dataset and convert ...

最新文章

  1. UDP(socket)接和数据案例封装成C++代码
  2. 牛客 - umi和弓道(几何+贪心)
  3. 每周分享第 19 期(20190426)
  4. python3列表_Python3 列表List(十一)
  5. 学编程必备的三个网站
  6. CentOS7救援模式以及救援模式的网络配置
  7. 40.leetcode17_letter_combinations_of_a_phone_number
  8. CentOS 7 多网卡绑定
  9. .NET框架类在ASP.NET中的使用(1)——QA
  10. 传智播客html视频教程(第六季) 杨中科
  11. 夏普ar2048s打印机驱动安装_驱动人生 下载安装打印机驱动的方法
  12. 3dmax 导出 fbx文件, 模型 到Unity中 贴图丢失
  13. 【网络科普】NAS和SAN - 网络附加存储和存储区域网络
  14. MicroDicom viewer(Dicom格式看图软件) v3.4.7官方版
  15. 基于边界凹凸点和神经网络的粘连颗粒图像分割算法研究(既然有网友要源代码研究,在此公开绝大部分源代码)
  16. Mac 修改移动硬盘图标,U盘图标
  17. 电脑C盘满了如何扩充C盘内存?
  18. OFD文件转PDF怎么转换?教你一键转换方法
  19. C# 微信证书签名,WECHATPAY2-SHA256-RSA2048 签名方式
  20. java 二义性_Java接口默认方法带来的问题分析【二义性问题】

热门文章

  1. SQL语句增加列、修改列类型、修改列、删除列
  2. jquery输入框按下回车提交表单
  3. Arcengine实现创建网络数据集札记(二)
  4. Maven查看插件信息
  5. JOpt Simple OptionParser解析命令参数
  6. 程序代码移植和烧录需要注意什么_法人变更需要注意什么
  7. 计算机电子的危害,电子垃圾焚烧炉的危害有多大,你了解过吗?
  8. 关系型数据库 vs 非关系型数据库
  9. 提高github访问速度(深入研究底层网络通信、域名解析等原理)
  10. Spring重点面题总结