Попробуйте использовать метод 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"});