码迷,mamicode.com
首页 > 其他好文 > 详细

原来DataTable的Distinct竟如此简单!

时间:2014-11-07 18:45:04      阅读:193      评论:0      收藏:0      [点我收藏+]

标签:style   ar   os   sp   for   数据   on   bs   ad   

DataView可以帮我们直接获取Distinct数据,

DataTable dataTable;DataView dataView = dataTable.DefaultView;

DataTable dataTableDistinct = dataView.ToTable(true,"FieldName1","FieldName2","...");

//注:其中ToTable()的第一个参数为是否DISTINCT

DataTable MyTable = ds.Tables[2]; //ds为数据集

DataTable dtClone = MyTable.Clone();  //创建新表
DataView dv = new DataView(dtClone);  //用于查找
dv.Sort = "Item";
foreach(DataRow dr in MyTable.Rows)   //单循环, 效率高一点
{
  int rowIndex = dv.FindRow(dr["Item"]);
  if (rowIndex == -1)
  {
    dtClone.ImportRow(dr);  //添加行
    dtClone.Rows[dtClone.Rows - 1] ["Quantity"] = (decimal)MyTable.Compute("Sum(Quantity)", string.Format("Item = ‘{0}‘", dr["Item"].ToString()); //合计
  }
}
dtClone.AcceptChanges();

ds.Tables.Remove(MyTable);  //删除旧表
ds.Tables.Add(dtClone);     //添加新表

dtClone.Rows[dtClone.Rows.Count - 1] ["Quantity"] = (decimal)MyTable.Compute("Sum(Quantity)", string.Format("Item = ‘{0}‘", dr["Item"].ToString()); //合计

原来DataTable的Distinct竟如此简单!

标签:style   ar   os   sp   for   数据   on   bs   ad   

原文地址:http://www.cnblogs.com/Unrmk-LingXing/p/4081957.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!