转自: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; 
}

最新文章

  1. Coursera-Getting and Cleaning Data-week1-课程笔记
  2. 七种常见阈值分割代码(Otsu、最大熵、迭代法、自适应阀值、手动、迭代法、基本全局阈值法)
  3. IPC---信号量
  4. iOS开发之 Xcode 5 下让你的应用在不同状态(debug, release)有不同的图标
  5. jQuery实现图片轮播
  6. Vivado学习笔记_002
  7. Oracle初级入门 根据某字段重复只取一条记录,并计计算重复条数
  8. [Swust OJ 1026]--Egg pain&#39;s hzf
  9. Eclipse配置Tomcat服务器
  10. 使用quartz实现不重启服务器修改自定义配置
  11. lambda隐藏函数的嵌套
  12. Android横竖屏切换生命周期变化
  13. NC 数据库操作
  14. Django之前后端交互使用ajax的方式
  15. BW中DSO的分类及应用
  16. TFLearn 与 Tensorflow 一起使用
  17. redie config 详解
  18. Church 整数前驱的推导
  19. 用Struts2实现列表显示和分页功能
  20. IE的if条件判断

热门文章

  1. day71
  2. Oracle 批量修改某个用户下表的表空间
  3. Centos7-安装Gradle4.10
  4. 20155310 Exp9 Web安全基础实践
  5. mapreduce中控制mapper的数量
  6. HTML 头部 (head) 实例
  7. Beta阶段展示博客
  8. git初次推送
  9. PAT甲题题解-1059. Prime Factors (25)-素数筛选法
  10. ajax请求超时判断(转载)