首页 技术 正文
技术 2022年11月15日
0 收藏 546 点赞 3,127 浏览 1498 个字

取数据的时候,存储过程返回了多个结果集,后台用DataSet去接收这几个结果集,然后接收之后,需要将结果集转换为不同的实体,于是下面的代码便出现了。

        /// <summary>
/// 将DataSet转换为泛型集合
/// </summary>
/// <typeparam name="T">泛型</typeparam>
/// <param name="dataSet">DataSet对象</param>
/// <param name="tableIndex">表索引</param>
/// <returns>返回泛型</returns>
public static IList<T> DataSetToIList<T>(DataSet dataSet, int tableIndex)
{
if (dataSet == null || dataSet.Tables.Count < 0)
return null;
if (tableIndex > dataSet.Tables.Count - 1)
return null;
if (tableIndex < 0)
tableIndex = 0; var tableData = dataSet.Tables[tableIndex];
// 返回值初始化
IList<T> result = new List<T>();
for (var j = 0; j < tableData.Rows.Count; j++)
{
var _t = (T)Activator.CreateInstance(typeof(T));
var propertys = _t.GetType().GetProperties();
foreach (var pi in propertys)
{
for (var i = 0; i < tableData.Columns.Count; i++)
{
// 属性与字段名称一致的进行赋值
if (!pi.Name.Equals(tableData.Columns[i].ColumnName)) continue;
// 数据库NULL值单独处理
pi.SetValue(_t, tableData.Rows[j][i] != DBNull.Value ? tableData.Rows[j][i] : null, null);
break;
}
}
result.Add(_t);
}
return result;
} /// <summary>
/// DataSet装换为泛型集合
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dataSet">DataSet</param>
/// <param name="tableName">待转换数据表名称</param>
/// <returns>返回指定的list</returns>
public static IList<T> DataSetToIList<T>(DataSet dataSet, string tableName)
{
var tableIndex = 0;
if (dataSet == null || dataSet.Tables.Count < 0)
return null;
if (string.IsNullOrEmpty(tableName))
return null;
for (var i = 0; i < dataSet.Tables.Count; i++)
{
// 获取Table名称在Tables集合中的索引值
if (!dataSet.Tables[i].TableName.Equals(tableName)) continue;
tableIndex = i;
break;
}
return DataSetToIList<T>(dataSet, tableIndex);
}

  

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,086
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,561
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,410
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,183
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,820
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,903