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