C# Datatable排序与取前几行数据

本文介绍如何在C#中实现Datatable的排序功能,并提供了具体的代码实例。同时,还分享了一种获取Datatable前几条数据的方法。

在C#中要对Datatable排序,可使用DefaultView的Sort方法。先获取Datatable的DefaultView,然后设置 得到的Dataview的sort属性,最后用视图的ToTable方法将排好序的dataview导出为Datatable。
     代码如下:
           

一、 Datatable排序

1
2
3
4
5
6
7
8
9
10
11
12
13
14
DataTable dt = new DataTable();
    dt.Columns.Add("ID", typeof(int));
    dt.Columns.Add("Name", typeof(string));
 
    dt.Rows.Add(new object[] { 12, "lwolf" });
    dt.Rows.Add(new object[] { 100,"kkkkk"});
    dt.Rows.Add(new object[] { 19,"jim" });
    dt.Rows.Add(new object[] { 1,"test" });
 
    DataTable dtCopy = dt.Copy();
 
    DataView dv = dt.DefaultView;
    dv.Sort = "ID";
    dtCopy = dv.ToTable();

  

1
二、获取DataTable前几条数据

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#region 获取DataTable前几条数据 
/// <summary> 
/// 获取DataTable前几条数据 
/// </summary> 
/// <param name="TopItem">前N条数据</param> 
/// <param name="oDT">源DataTable</param> 
/// <returns></returns> 
public static DataTable DtSelectTop(int TopItem, DataTable oDT) 
    if (oDT.Rows.Count < TopItem) return oDT; 
   
    DataTable NewTable = oDT.Clone(); 
    DataRow[] rows = oDT.Select("1=1"); 
    for (int i = 0; i < TopItem; i++) 
    
        NewTable.ImportRow((DataRow)rows[i]); 
    
    return NewTable; 
#endregion 

转载于:https://www.cnblogs.com/Impulse/articles/5868903.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值