(转)DATATABLE(DATASET)与实体类之间的互转.
2024-09-28 01:51:21
转自:http://www.cnblogs.com/zzyyll2/archive/2010/07/20/1781649.html
dataset和实体类 之间的转换
//dataset转实体类
代码
public static IList<T> FillModel(DataSet ds)
{
List<T> l = new List<T>();
T model = default(T); if (ds.Tables[0].Columns[0].ColumnName == "rowId")
{
ds.Tables[0].Columns.Remove("rowId");
} foreach (DataRow dr in ds.Tables[0].Rows)
{ model = Activator.CreateInstance<T>(); foreach (DataColumn dc in dr.Table.Columns)
{ PropertyInfo pi = model.GetType().GetProperty(dc.ColumnName);
if (dr[dc.ColumnName] != DBNull.Value)
pi.SetValue(model, dr[dc.ColumnName], null);
else
pi.SetValue(model, null, null); }
l.Add(model);
} return l; }
将实体类转换成DataTable
代码 /// <summary>
/// 将实体类转换成DataTable
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="i_objlist"></param>
/// <returns></returns>
public static DataTable Fill<T>(IList<T> objlist)
{
if (objlist == null || objlist.Count <= 0)
{
return null;
}
DataTable dt = new DataTable(typeof(T).Name);
DataColumn column;
DataRow row; System.Reflection.PropertyInfo[] myPropertyInfo = typeof(T).GetProperties(BindingFlags.Public | BindingFlags.Instance); foreach (T t in objlist)
{
if (t == null)
{
continue;
} row = dt.NewRow(); for (int i = 0, j = myPropertyInfo.Length; i < j; i++)
{
System.Reflection.PropertyInfo pi = myPropertyInfo[i]; string name = pi.Name; if (dt.Columns[name] == null)
{
column = new DataColumn(name, pi.PropertyType);
dt.Columns.Add(column);
} row[name] = pi.GetValue(t, null);
} dt.Rows.Add(row);
}
return dt;
}
最新文章
- Coursera-Getting and Cleaning Data-week1-课程笔记
- 七种常见阈值分割代码(Otsu、最大熵、迭代法、自适应阀值、手动、迭代法、基本全局阈值法)
- IPC---信号量
- iOS开发之 Xcode 5 下让你的应用在不同状态(debug, release)有不同的图标
- jQuery实现图片轮播
- Vivado学习笔记_002
- Oracle初级入门 根据某字段重复只取一条记录,并计计算重复条数
- [Swust OJ 1026]--Egg pain&#39;s hzf
- Eclipse配置Tomcat服务器
- 使用quartz实现不重启服务器修改自定义配置
- lambda隐藏函数的嵌套
- Android横竖屏切换生命周期变化
- NC 数据库操作
- Django之前后端交互使用ajax的方式
- BW中DSO的分类及应用
- TFLearn 与 Tensorflow 一起使用
- redie config 详解
- Church 整数前驱的推导
- 用Struts2实现列表显示和分页功能
- IE的if条件判断