Spróbuj użyć metody DataColumn.SetOrdinal . Na przykład:
dataTable.Columns["Qty"].SetOrdinal(0);
dataTable.Columns["Unit"].SetOrdinal(1);
AKTUALIZACJA: Ta odpowiedź przyciągnęła dużo więcej uwagi, niż się spodziewałem. Aby uniknąć nieporozumień i ułatwić korzystanie, zdecydowałem się utworzyć metodę rozszerzającą porządkowanie kolumn w DataTable:
Metoda przedłużenia:
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++;
}
}
}
Stosowanie:
table.SetColumnsOrder("Qty", "Unit", "Id");
lub
table.SetColumnsOrder(new string[]{"Qty", "Unit", "Id"});