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


    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(); 
      
  • 相关阅读:
    测试VPS
    [转] 如何在vps上安装和登录Xwindows
    [转]设置修改CentOS系统时区
    顺序队列
    求二叉树的高度
    VMware Workstation cannot connect to the virtual machine
    如何查看hadoop是32位还是64位
    64位CentOS上编译 Hadoop 2.2.0
    hadoop 2.X下eclipse配置
    删除文件及文件夹
  • 原文地址:https://www.cnblogs.com/beeone/p/3618081.html
Copyright © 2020-2023  润新知