[转]关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法
2009-06-30 14:40
453 查看
在实际编程工程中,常常遇到这样的情况:DataTable并不是数据库中的,或者DataTable尚未写到数据库,或者从数据库中读出的DataTable已经在本地被改动,又没有写回数据库(可能还要作其他改动),在这些情况下,其实只要用.NET类库中提供的DataView类的强大功能(主要是用它的RowFilter属性),就能方便地解决这类查询问题。
常有网友在网上询问怎么在DataTable中执行DataTable.Select("条件")返回DataTable,今天我在这里给个解决方法给大家参考:
代码如下
Code
//// <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()方法仅仅复制结构信息,不拷贝数据
常有网友在网上询问怎么在DataTable中执行DataTable.Select("条件")返回DataTable,今天我在这里给个解决方法给大家参考:
代码如下
Code
//// <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()方法仅仅复制结构信息,不拷贝数据
相关文章推荐
- 关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法[转载]
- 关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法
- [datatable]关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法
- 学习:关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法(转)
- 关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法
- 关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法
- 关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法
- 在DataTable中执行Select("条件")后,返回DataTable的方法
- DataTable.Select("条件")返回DataTable的解决方法
- 在DataTable中执行Select("条件")后,返回DataTable的方法
- 在DataTable中执行Select("条件")后,返回DataTable的方法
- DataTable中执行DataTable.Select("条件")返回DataTable的方法
- DataTable:执行DataTable.Select("条件")返回DataTable的解决方法
- 在DataTable中执行DataTable.Select("条件")返回DataTable;
- 在DataTable中执行DataTable.Select("条件")返回DataTable;
- 将DataTable中执行Select(\"条件\")后的结果显示在DataGridView
- 关于IE抛出"不能执行已释放 script 的代码"的解决方法
- 在DataTable中执行DataTable.Select("条件"),
- 在DataTable中执行DataTable.Select("条件")
- 关于Android原生集成5+webview,监听webview返回时,执行两次onkey方法问题的解决