dataset和实体类 之间的转换
2009-08-13 22:08
375 查看
//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;
}
/// <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;
}
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;
}
/// <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;
}
相关文章推荐
- dataset和实体类 之间的转换
- dataset和实体类 之间的转换
- dataset和实体类 之间的转换
- XML和实体类之间相互转换(序列化和反序列化)
- [XML]XML与Datatalbe_DataSet_之间的相互转换
- c# XML和实体类之间相互转换(序列化和反序列化)
- XML格式的字符串与DataSet之间的转换
- XML与实体类,DataTable,List之间进行转换
- 使用XStream处理Xml文档和实体类之间的转换的几种方式
- 含实体类、Set集合的JavaBean与Json之间的转换,以及在JS中读取
- json <--->List集合,实体类 之间的相互转换
- Asp.net中XML与DataSet、DataTable之间的转换
- XML和实体类之间相互转换(序列化和反序列化)
- [XML]XML与Datatalbe_DataSet_之间的相互转换
- [代码篇]Dataset 和 byte[] 之间的转换
- DataSet与Xml之间的转换
- DataSet和实体类的相互转换
- (转)DATATABLE(DATASET)与实体类之间的互转.
- c# XML和实体类之间相互转换(序列化和反序列化)(转)
- DataSet和List<T> 泛型之间互相转换 (转载, 作者写的很好)