C# DataTable排序、查询、合并操作

DataTable查询。  


里说到的查询有两种。

1.DataTable.Select
2.DataTable.Rows.Find

a>先建立一个DataTable供使用吧。

 
    

  ///
        /// 获取单张表
        ///
        ///
        public static DataTable GetTable()
        {
            DataTable dt = new DataTable();
            dt . Columns . Add ( new   DataColumn ( "Id" ,   typeof ( int )));
            dt . Columns . Add ( new   DataColumn ( "Name" ,   typeof ( string )));
            dt . Columns . Add ( new   DataColumn ( "Age" ,   typeof ( int )));
             DataRow  dr  =  dt . NewRow ();
            dr [ "Id" ]   =   1 ;
            dr [ "Name" ]   =   "tangh" ;
            dr [ "Age" ]   =   20 ;
            dt . Rows . Add ( dr );
            dr  =  dt . NewRow ();
            dr [ "Id" ]   =   2 ;
            dr [ "Name" ]   =   "tangha" ;
            dr [ "Age" ]   =   19 ;
            dt . Rows . Add ( dr );
            dr  =  dt . NewRow ();
            dr [ "Id" ]   =   3 ;
            dr["Name"] = "tanghao";    
dr [ "Age" ] = 21 ;
            dt . Rows . Add ( dr );
            return dt ;
        }


         
2.然后我们来使用第一种Select方法。
 
   

///

/// 使用DataTable.Select方法检索 /// public static void VilideDataTableSelect() { DataTable dt = GetTable(); // 类似where条件查询,可以使用Id=2 and Name=ddd DataRow[] rows = dt.Select("Id=2 and Name like 'tang%'"); // select类似where条件 foreach (DataRow dr in rows) { Console.Write(string.Format("Id={0},Name={1},Age={2}", dr["Id"], dr["Name"], dr["Age"])); } }

3.最后使用以下,Find方法。
 
    

///

/// 使用DataTable.Rows.Find方法检索 /// public static void VilideDataRowFind() { DataTable dt = GetTable(); // 设置主键,可以使用复合主键 dt.PrimaryKey = new DataColumn[] { dt.Columns["Id"] }; DataRow dr = dt.Rows.Find(2); // 查找Id=2的。即,这里检索主键。 Console.Write(string.Format("Id={0},Name={1},Age={2}", dr["Id"], dr["Name"], dr["Age"])); }

 1、排序     1.1、利用查询排序

DataRow[] dataRows = dataTable.Select("条件", "id asc"); //或多列排序 DataRow[] dataRows = dataTable.Select("条件", "id asc,name asc,..."); //对所有的进行排序 DataRow[] dataRows = dataTable.Select("1=1", "id asc,name asc,...");

    1.2、默认视图排序

DataView dataView = dataTable.DefaultView; dataView.Sort = "id asc"; dataTable = dataView.ToTable();

    2、搜索
    如果单纯搜索,

DataRow[] dataRows = dataTable.Select("条件");

或者

int id; string name; DataRow[] dataRows = dataTable.Select(string.Format(@"id={0} and name={1}",id,name));

如果对搜索结果排序,如同1.1。
     说明:select方法如同sql语句对单表的查询,条件如同sql语句的where之后的部分,>,<,=,LIKE等都可以使用。
    3、合并
    合并的对象必须结构要一致,如果不一致先转换一致。然后,利用Merge方法,

DataTable dataTable1 = null; DataTable dataTable2 = null; dataTable1.Merge(dataTable2);

你可能感兴趣的:(C#)