c#

c# datatable排序时如何保证顺序

小樊
95
2024-07-17 03:23:44
栏目: 编程语言

在C#中,可以使用DataView对象来对DataTable进行排序,并且保持原始顺序。以下是一个示例代码:

// 创建一个DataTable
DataTable dt = new DataTable();
dt.Columns.Add("ID", typeof(int));
dt.Columns.Add("Name", typeof(string));

// 添加数据到DataTable
dt.Rows.Add(1, "Alice");
dt.Rows.Add(2, "Bob");
dt.Rows.Add(3, "Charlie");

// 使用DataView对象对DataTable进行排序
DataView dv = new DataView(dt);
dv.Sort = "Name ASC";

// 遍历排序后的数据,并保持原始顺序
foreach (DataRowView drv in dv)
{
    int id = (int)drv["ID"];
    string name = (string)drv["Name"];
    
    Console.WriteLine($"ID: {id}, Name: {name}");
}

// 输出原始顺序的数据
foreach (DataRow row in dt.Rows)
{
    int id = (int)row["ID"];
    string name = (string)row["Name"];
    
    Console.WriteLine($"ID: {id}, Name: {name}");
}

在上面的示例中,首先创建了一个包含ID和Name列的DataTable,并添加了几行数据。然后使用DataView对象对DataTable按Name列进行升序排序。最后通过遍历DataView对象和原始DataTable对象,可以看到排序后的数据以及保持原始顺序的数据。

0
看了该问题的人还看了