Coba gunakan metode DataColumn.SetOrdinal . Sebagai contoh:
dataTable.Columns["Qty"].SetOrdinal(0);
dataTable.Columns["Unit"].SetOrdinal(1);
UPDATE: Jawaban ini mendapat perhatian lebih dari yang saya harapkan. Untuk menghindari kebingungan dan membuatnya lebih mudah digunakan, saya memutuskan untuk membuat metode ekstensi untuk pengurutan kolom di DataTable:
Metode ekstensi:
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++;
}
}
}
Pemakaian:
table.SetColumnsOrder("Qty", "Unit", "Id");
atau
table.SetColumnsOrder(new string[]{"Qty", "Unit", "Id"});