首页 > 其他 > 详细

[datatable]关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法

时间:2014-03-23 09:33:52      阅读:273      评论:0      收藏:0      [点我收藏+]
bubuko.com,布布扣
009-04-26 11:09关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法
在实际编程工程中,常常遇到这样的情况:DataTable并不是数据库中的,或者DataTable尚未写到数据库,或者从数据库中读出的DataTable已经在本地被改动,又没有写回数据库(可能还要作其他改动),在这些情况下,其实只要用.NET类库中提供的DataView类的强大功能(主要是用它的RowFilter属性),就能方便地解决这类查询问题。
常有网友在网上询问怎么在DataTable中执行DataTable.Select("条件")返回DataTable,今天我在这里给个解决方法给大家参考:
代码如下

 /**//// <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 dr=dt.Select(学号=108)[0]; 
      string sss = dr[姓名].ToString(); 
例:DataRow[] rows = dt.Select(学号=108);
if(rows.Length   0)
{
string sss = rows[0][姓名].ToString();
}
例:Select后,框架不会变的,Select只是筛选记录,不会改变列。 
  
string name=string.Empty; 
DataRow[] rows = dt.Select(学号=108); 
if (rows!=null   rows.Length0) 
   name=rows[0][姓名].ToString();//第0行即返回值的第一行,即返回结果
例:string sss = dt.Select( 姓名= from Tables[0] where [学号]=108).ToString(); 
  
bubuko.com,布布扣

[datatable]关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法,布布扣,bubuko.com

[datatable]关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法

原文:http://www.cnblogs.com/beeone/p/3618081.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!