学习:关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法(转)...


在 实际编程工程中,常常遇到这样的情况:DataTable并不是数据库中的,或者DataTable尚未写到数据库,或者从数据库中读出的 DataTable已经在本地被改动,又没有写回数据库(可能还要作其他改动),在这些情况下,其实只要用.NET类库中提供的DataView类的强大 功能(主要是用它的RowFilter属性),就能方便地解决这类查询问题。
常有网友在网上询问怎么在DataTable中执行DataTable.Select("条件")返回DataTable,今天我在这里给个解决方法给大家参考:
代码如下:

ContractedBlock.gif   ///<summary>
 
/// 执行DataTable中的查询返回新的DataTable
 
/// </summary>
 
/// <param name="dt">源数据DataTable</param>
 
/// <param name="condition">查询条件</param>
 
/// <returns></returns>
  private DataTable GetNewDataTable(DataTable dt,string condition)
  {            
      DataTable newdt 
= new DataTable(); 
      newdt
=dt.Clone();
      DataRow[] dr 
= dt.Select(condition); 
      
for(int i=0;i<dr.Length;i++
      { 
          newdt.ImportRow((DataRow)dr[i]);
      } 
      
return newdt;//返回的查询结果
   }

 

嘿嘿,都是一样的,循环添加行

DataRow[] rows  =  dt.Select(conditions); 
foreach (DataRow row  in  rows) 

    newdt.Rows.Add(row.ItemArray); 

return  newdt;

davin: 我今天下午也是遇到这样一个问题,关于datatable 的过滤问题,我要求取出过滤后结果的前20条,一直徘徊在filterRow和select方法之间,filterrow性能很差,select()返回 dataRow[]不好操作,不过看到你的做法,dt.Clone();
性能确实很严重,如果dt是一个大数据量的表
--------------------------------------------------------
dt.clone()应该没有性能问题。
clone()方法仅仅复制结构信息,不拷贝数据


文章来源:http://www.cnblogs.com/purplefox2008/archive/2009/11/01/1593921.html

 

转载于:https://www.cnblogs.com/LeimOO/archive/2009/11/05/1596809.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值