DataTable 排序

 
DataRow[] rows = dataTable1.Select("", "ord asc");
 
DataTable t = DataTable1.Clone();
 
t.Clear();
 
foreach (DataRow row in rows)
 
    t.ImportRow(row);
 
DataTable1 = t;
 
VS2005中这种方法最简单:
DataView dv = dt.DefaultView;
dv.Sort = "c1 Asc";
DataTable dt2 = dv.ToTable();
 
--------------------------
 
//拿到数据源
DataView dv = this.dtDataSource.Copy().DefaultView;
//排序
dv.Sort = "款 asc,項 asc,目 asc";
//过滤重复数据
//DataTable dt = dv.ToTable(true, "款", "項", "目");
//不过滤重复数据
DataTable dt = dv.Table.Copy();  
 
-----------------------------------------------
 
关于DataView(DataTable)排序的思考
       因项目需要,在获得<a target="_blank" style="color: #0000F0; display:inline; position:static; background:none;" href="http://www.so.com/s?q=dataset&ie=utf-8&src=se_lighten_f">dataset</a>(或者DataTable)之后要对该table进行重新排序,排序规则按照<a target="_blank" style="color: #0000F0; display:inline; position:static; background:none;" href="http://www.so.com/s?q=%E6%95%B0%E7%BB%84&ie=utf-8&src=se_lighten_f">数组</a>fids元素的顺序进行。
 
在测试的时候,我用简单的思考方法,在table上增加一列dis,来存放该行的主键在fids中的对应项的索引,一个循环之后,dis都被赋了值,现在就要排序了,因为datatable没有排序功能,就选择了转换DataTable为DataView,然后对DataView进行排序,关键代码如下:
 
DataView dw = dt.DefaultView;
 
dw.Sort = "dis,发布日期 desc";
 
然后把dw绑定到DataGird输出,结果正好符合原意。
 
可是具体使用中却出了问题,因为我对dw又进行了一次处理,取该分页需要的某几项绑定到DataGird,于是结果和排序之前一样,没有了变化。
 
究其原因,才发现,这里的DataView只是设定了排序规则,并没有实施排序,那么排序在什么时候发生呢,应该是在绑定到DataGird的时候才发生,所以我后来的方法就出了问题。
 
总结如下:DataView的筛选和排序功能都是在绑定到数据控件的时候才执行的,如果你是简单的需求(也就是说不需要再取其中的部分数据来绑定数据控件),那就可以使用该功能。
 
我的问题的最终解决方法如下(只使用了简单的循环):
 
private DataTable SortTable(DataTable dt,string[] pids)
 
         {
 
              DataTable dt0 = dt.Clone(); //复制原表结构
 
              for(int i=0;i<pids.Length;i++)
 
              {
 
                   if(pids[i] != string.Empty)
 
                   {
 
                       DataRow[] drs = dt.Select("pos_id=" + pids[i]);
 
                       if(drs.Length > 0)
 
                       {
 
                            foreach(DataRow dr in drs)
 
                            {
 
                                 dt0.ImportRow(dr); //导入行
 
                            }
 
                       }
 
                   }
 
              }
 
              return dt0;
 
     }
 
说明:就是对排序的数组循环,在datatable中找对应的行,然后复制到新表中。
 
 
该方法的效率还是可以的,不过如果交集次数大于20,000,000的时候,就会有效率问题。
 
****************************************************************
 
  
 
dstaset.Tables.Add(dt)
dataset.Tables(0).DefaultView.Sort = "id desc"
 
dv = New DataView(dt)
dv.Sort = "id desc"
 
dv = New DataView(ds.Tables[0])
dv.Sort = "id desc"-------------------------------------------------------------- System.Data.DataTable table = new System.Data.DataTable();
            table.Columns.Add("aa", typeof(string));
            System.Data.DataRow row = table.NewRow();
            row["aa"] = "sdf";
            table.Rows.Add(row);
 
            System.Data.DataView dv = new System.Data.DataView(table);
 
            table.Columns.Add("bb", typeof(string)); DataTable dt = con.getDGResulthk(sql);
            DataColumn col1 = con.getCol(sql1);
            DataColumn col = dt.Columns.Add("工资");
            DataRow dr = dt.NewRow();
            dr["工资"] = col1;
            dt.Rows.Add(dr);
            dataGridView1.DataSource = dt;
             
            dataGridView1.AutoResizeColumns();
 System.Data.DataTable table = new System.Data.DataTable();
            table.Columns.Add("aa", typeof(string));
            System.Data.DataRow row = table.NewRow();
            row["aa"] = "sdf";
            table.Rows.Add(row);
 
            System.Data.DataView dv = new System.Data.DataView(table);
 
  
 
  
 
DataTable drReport=new DataTable();
 
DataRow[] pdrs111 = dtReport.Select("code=''" + strNoCode + "''");
                        if (pdrs111.Length > 0)
                        {
                            foreach (DataRow dr111 in pdrs111)
                            {
                                decfd_1 = Convert.ToDouble(dr111["fd"].ToString());
                                dr111["fd_no"] = dtNOValue;
                                dr111["fd_no_toal"] = decfd_1 + dtNOValue;
                            }
                        }
 
 
 
  
 
  
 
dstaset.Tables.Add(dt)
dataset.Tables(0).DefaultView.Sort = "id desc"
 
dv = New DataView(ds.Tables[0])
dv.Sort = "id desc"
 
from: http://www.cnblogs.com/xiaofengfeng/archive/2012/06/27/2565941.html

DataTable排序(转)的更多相关文章

  1. C# dataTable 排序

    DataView dv = ds.DefaultView; dv.Sort = "header asc"; ds = dv.ToTable(); C# dataTable 排序

  2. C# Datatable排序

    在C#中要对Datatable排序,可使用DefaultView的Sort方法.先获取Datatable的DefaultView,然后设置 得到的Dataview的sort属性,最后用视图的ToTab ...

  3. C# 对Datatable排序

    一,在C#中要对Datatable排序,可使用DefaultView的Sort方法.先获取Datatable的DefaultView,然后设置 得到的Dataview的sort属性,最后用视图的ToT ...

  4. [DataTable]控件排序事件中用DataView及DataTable排序

    控件排序事件中用DataView及DataTable排序 文章分类:.net编程 在做ASP.NET页面开发时,经常要用到dataset(或者DataTable),绑定到DataGrid或GridVi ...

  5. 在C#中对Datatable排序【DefaultView的Sort方法】

    在C#中对Datatable排序,[DefaultView的Sort方法] 代码如下: DataTable dt = new DataTable(); dt.Columns.Add("ID& ...

  6. DataTable排序(来自其他空间)

    DataTable排序 DataRow[] rows = dataTable1.Select("", "ord asc"); DataTable t = Dat ...

  7. C# Datatable排序(转)

    C# Datatable排序 在C#中要对Datatable排序,可使用DefaultView的Sort方法.先获取Datatable的DefaultView,然后设置得到的Dataview的sort ...

  8. 【转】C# Datatable排序与取前几行数据

    转自:http://www.cnblogs.com/linyechengwei/archive/2010/06/14/1758337.html http://blog.csdn.net/smartsm ...

  9. DataSet,DataTable排序(转载)

    DataSet,DataTable排序   关于对已经绑定的DataSet的排序的问题: DataSet ds=new DataSet();DataView dv=new DataView();dv. ...

随机推荐

  1. 滤镜与CSS3效果

    -webkit-filter是css3的一个属性,Webkit率先支持了这几个功能,感觉效果很不错.一起学习一下filter这个属性吧. 现在规范中支持的效果有: grayscale 灰度       ...

  2. NPOI 操作Excel

    关于NPOI NPOI是POI项目的.NET版本,是由@Tony Qu(http://tonyqus.cnblogs.com/)等大侠基于POI开发的,可以从http://npoi.codeplex. ...

  3. Java String.split()用法小结

    在java.lang包中有String.split()方法,返回是一个数组 我在应用中用到一些,给大家总结一下,仅供大家参考: 1.如果用“.”作为分隔的话,必须是如下写法,String.split( ...

  4. (转)oracle 存储过程 带游标作为OUT参数输出

    (转)oracle 存储过程 带游标作为OUT参数输出 存储过程返回OUT参数的游标 例子. 包中带过程 要自己定义一个type [cur_name] is ref cursor游标,返回的时候就直接 ...

  5. 域环境下装SQL SERVER的一次惨痛经历

    SQL SERVER 2008 R2 其实sql server不建议装在域环境下的,但sharepoint必须用域用户来连接.这本来也不是个什么大问题,但是,这一次相当的不顺利哦. 我有单独的域控,单 ...

  6. Linux线程-互斥锁pthread_mutex_t

    在线程实际运行过程中,我们经常需要多个线程保持同步.这时可以用互斥锁来完成任务:互斥锁的使用过程中,主要有pthread_mutex_init,pthread_mutex_destory,pthrea ...

  7. android setVisibility失效不起作用的问题

    原因:不同的布局中有名字相同的控件,所以adapter中填充item的时候,由于控件名字相同没有正确识别你要显示的控件. 解决方法:给其中一个控件改一下名字就行了,超简单.

  8. Thrift 个人实战--Thrift 网络服务模型

    前言: Thrift作为Facebook开源的RPC框架, 通过IDL中间语言, 并借助代码生成引擎生成各种主流语言的rpc框架服务端/客户端代码. 不过Thrift的实现, 简单使用离实际生产环境还 ...

  9. Neo4j Index Notes

    Motivation GraphDatabasesBook: Robinson I., Webber J., Eifrem E. Graph Databases. 2013. 这本该是入门概念性质的书 ...

  10. Scramble String

    Given a string s1, we may represent it as a binary tree by partitioning it to two non-empty substrin ...