Попробуйте использовать метод DataColumn.SetOrdinal . Например:
dataTable.Columns["Qty"].SetOrdinal(0);
dataTable.Columns["Unit"].SetOrdinal(1);
ОБНОВЛЕНИЕ: этот ответ привлек гораздо больше внимания, чем я ожидал. Чтобы избежать путаницы и упростить использование, я решил создать метод расширения для упорядочивания столбцов в DataTable:
Способ расширения:
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++;
}
}
}
Применение:
table.SetColumnsOrder("Qty", "Unit", "Id");
или
table.SetColumnsOrder(new string[]{"Qty", "Unit", "Id"});