C#将LINQ数据集转换为Datatable
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相关推荐
- ListT转换为DataTable
关于List<T>转换为DataTable的问题一直是开发过程中经常用到的,现从网上整理几个常用的转换方式,留作备用. (尊重作者原创,本文代码转发自 List 与 DataTable 转 ...
- 把ListT转换为DataTable
下面这个学习,把List<T>转换为Datatable. 下面先创建一个对象T: class Ay{private int _ID;public int ID{get { return _ ...
- python将scikit-learn自带数据集转换为pandas dataframe格式
python将scikit-learn自带数据集转换为pandas dataframe格式 目录 python将scikit-learn自带数据集转换为pandas dataframe格式 #仿真数据
- 将DataRow转换为DataTable
/// <summary>/// DataRow转换为DataTable/// </summary>/// <param name="dt">& ...
- 将数据集转换为Excel格式的一个实现
{ 将数据集转换为Excel格式的一个实现 在做项目时,很多情况下,客户需要对我们保存在数据库中的数据再加工再利用, 如财务需要一份今年财务情况的电子报表,总经理需要今年销售情况的一个电子报表. 我们 ...
- C# 数组转换为DataTable 的三个方法
using System; using System.Data; namespace ArrayToDataTable { class ArrayToDataTable { /// <summa ...
- SqlDataReader转换为DataTable
SqlDataReader转换为DataTable 作者:未知 时间: 2007-6-11 13:05:56 文档类型:未知 来自:未知 浏览统计:37 代码一: private void ...
- Pytorch机器学习(三)——VOC数据集转换为YOLO数据集
Pytorch机器学习(三)--VOC数据集转换为YOLO数据集 目录 Pytorch机器学习(三)--VOC数据集转换为YOLO数据集 前言 一.yolo格式 二.代码 总结 前言 本文为利用pyt ...
- 将cityscapes数据集转换为19类 convert cityscapes to 19 categories
在用DANet网络时候,Readme里面提到了处理数据集时,提到了要把cityscapes数据集转换为19类: Download the Cityscapes dataset and convert ...
最新文章
- UDP(socket)接和数据案例封装成C++代码
- 牛客 - umi和弓道(几何+贪心)
- 每周分享第 19 期(20190426)
- python3列表_Python3 列表List(十一)
- 学编程必备的三个网站
- CentOS7救援模式以及救援模式的网络配置
- 40.leetcode17_letter_combinations_of_a_phone_number
- CentOS 7 多网卡绑定
- .NET框架类在ASP.NET中的使用(1)——QA
- 传智播客html视频教程(第六季) 杨中科
- 夏普ar2048s打印机驱动安装_驱动人生 下载安装打印机驱动的方法
- 3dmax 导出 fbx文件, 模型 到Unity中 贴图丢失
- 【网络科普】NAS和SAN - 网络附加存储和存储区域网络
- MicroDicom viewer(Dicom格式看图软件) v3.4.7官方版
- 基于边界凹凸点和神经网络的粘连颗粒图像分割算法研究(既然有网友要源代码研究,在此公开绝大部分源代码)
- Mac 修改移动硬盘图标,U盘图标
- 电脑C盘满了如何扩充C盘内存?
- OFD文件转PDF怎么转换?教你一键转换方法
- C# 微信证书签名,WECHATPAY2-SHA256-RSA2048 签名方式
- java 二义性_Java接口默认方法带来的问题分析【二义性问题】