DataTable排序(转)
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"
DataTable排序(转)的更多相关文章
- C# dataTable 排序
DataView dv = ds.DefaultView; dv.Sort = "header asc"; ds = dv.ToTable(); C# dataTable 排序
- C# Datatable排序
在C#中要对Datatable排序,可使用DefaultView的Sort方法.先获取Datatable的DefaultView,然后设置 得到的Dataview的sort属性,最后用视图的ToTab ...
- C# 对Datatable排序
一,在C#中要对Datatable排序,可使用DefaultView的Sort方法.先获取Datatable的DefaultView,然后设置 得到的Dataview的sort属性,最后用视图的ToT ...
- [DataTable]控件排序事件中用DataView及DataTable排序
控件排序事件中用DataView及DataTable排序 文章分类:.net编程 在做ASP.NET页面开发时,经常要用到dataset(或者DataTable),绑定到DataGrid或GridVi ...
- 在C#中对Datatable排序【DefaultView的Sort方法】
在C#中对Datatable排序,[DefaultView的Sort方法] 代码如下: DataTable dt = new DataTable(); dt.Columns.Add("ID& ...
- DataTable排序(来自其他空间)
DataTable排序 DataRow[] rows = dataTable1.Select("", "ord asc"); DataTable t = Dat ...
- C# Datatable排序(转)
C# Datatable排序 在C#中要对Datatable排序,可使用DefaultView的Sort方法.先获取Datatable的DefaultView,然后设置得到的Dataview的sort ...
- 【转】C# Datatable排序与取前几行数据
转自:http://www.cnblogs.com/linyechengwei/archive/2010/06/14/1758337.html http://blog.csdn.net/smartsm ...
- DataSet,DataTable排序(转载)
DataSet,DataTable排序 关于对已经绑定的DataSet的排序的问题: DataSet ds=new DataSet();DataView dv=new DataView();dv. ...
随机推荐
- iOS开发UI篇—控制器的创建
iOS开发UI篇—控制器的创建 说明:控制器有三种创建方式,下面一一进行说明. 一.第一种创建方式(使用代码直接创建) 1.创建一个空的IOS项目. 2.为项目添加一个控制器类. 3.直接在代理方法中 ...
- AspNetPager分页
1.页面部分 <%@ Register Assembly="AspNetPager" Namespace="Wuqi.Webdiyer" TagPrefi ...
- POJ 1094 Sorting It All Out 拓扑排序 难度:0
http://poj.org/problem?id=1094 #include <cstdio> #include <cstring> #include <vector& ...
- Client默认用户及登录密码(转)
Client默认用户及登录密码 SAP系统(如ERP.CRM等)安装完成,初始化状态下有若干个客户端(Client).如果是生产系统,一般只有000.001.066等三个Client:如果是IDES系 ...
- Redis应用场景(转)
(来源:http://www.cnblogs.com/shanyou/archive/2012/09/04/2670972.html) Redis常用数据类型 Redis最为常用的数据类型主要有以下五 ...
- 教你看懂GERBER中的钻孔(.txt)文件
PCB在制作的时候也会导出相应钻孔的坐标位置,但是发现网上很少有关于这方面的资料,而一些项目中,可能就会用到钻孔的坐标信息,今天就抛下砖. M48 ;Layer_Color=9474304 % 图层 ...
- SharePoint 2013 开发——搜索架构及扩展
博客地址:http://blog.csdn.net/FoxDave SharePoint 2013高度整合了搜索引擎,在一个场中只有一个搜索服务应用程序(SSA).它集成了FAST,只有一个代码库 ...
- ABOUT LIFETIME
This is where we started We've come a long way since our beginning. It all started as an idea in a g ...
- Wireshark找不到网络接口问题
Wireshark找不到网络接口问题 在运行Wireshark工具抓包时,需要有管理员用户权限.如果是普通用户启动的话,将会提示找不到网络接口.
- github常见操作和常见错误!错误提示:fatal: remote origin already exists.
如果输入$ git remote add origin git@github.com:djqiang(github帐号名)/gitdemo(项目名).git 提示出错信息:fatal: remote ...