高效率获取datatable中的重复参数

高效率获取和判断DataTable中的重复数据

方式一ToTable

DataTable aa=new DataTable();
//此处省略给DataTable赋值的代码
//aa 就是需要进行操作的DataTable
DataView myDataView = new DataView(aa)
string[] strComuns = { "orderid" };//这里是需要进行判断的字段
if (myDataView.ToTable(true, strComuns).Rows.Count < dt.Rows.Count)
{
//如果进入了这里就说明有重复
}

ToTale的效率比较低因为他需要一行一行的查,而且是把DataTable中的一行数据查完然后拿出进行判断的字段来进行对比,导致查询很慢。我在datatable里存了17万条数据。然后进行筛选重复。这个方法是非常慢的。慢到程序爆炸的那种。

方式二利用list的Contains

思路就是在新增DataTable数据的时候把已经添加过的数据的某个字段记录下来,存到list里面然后每新增一条就判断一次。这个方法比较快

Listr<string> orderlist=new  new List<string>();
DataTable Table = new DataTable("Order_Account");//这个是用于存数据的datatable
 Table.Columns.Add("id", typeof(int));
 Table.Columns.Add("orderid", typeof(string));
 Table.Columns.Add("ordertype", typeof(int));//给datataTable创建列
for(....)//循环往datatable里添加数据
{
DataRow dr = Table.NewRow();//创建行
 dr["orderid"] = orderid.TrimEnd();//往行里添加数据
 dr["ordertype"] = Typeval;
 dr["orgid"] = orgid;
//此处创建datatable的行也就是dataRow 我这里就省略了往里面
if(orderlist.Contains(orderid))
{
//重复了就会进入这里
//在这里可以做数据聚合
 DataRow[] row = Table.Select("orderid='"+orderid+"'");//查询出table已有的和这条需要新增的数据重复的数据。
 //row就是table表里的已有的那条数据。是一行的所有数据
continue;//跳出循环,也就不会往table里加入这行了。
}     
orderlist.add(dr["orderid"].tostring())
//将行 数据添加到table表里    
Table.Rows.Add(dr);
}
                                  {
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

或与且与或非

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值