Cố gắng sử dụng phương pháp DataColumn.SetOrdinal . Ví dụ:
dataTable.Columns["Qty"].SetOrdinal(0);
dataTable.Columns["Unit"].SetOrdinal(1);
CẬP NHẬT: Câu trả lời này nhận được nhiều sự chú ý hơn tôi mong đợi. Để tránh nhầm lẫn và dễ sử dụng hơn, tôi đã quyết định tạo một phương thức mở rộng để sắp xếp cột trong DataTable:
Phương thức mở rộng:
public static class DataTableExtensions
{
public static void SetColumnsOrder(this DataTable table, params String[] columnNames)
{
int columnIndex = 0;
foreach(var columnName in columnNames)
{
table.Columns[columnName].SetOrdinal(columnIndex);
columnIndex++;
}
}
}
Sử dụng:
table.SetColumnsOrder("Qty", "Unit", "Id");
hoặc là
table.SetColumnsOrder(new string[]{"Qty", "Unit", "Id"});