Удалить первичный ключ в datatable
есть ли способ удалить первичный ключ из datatable или есть ли способ сначала удалить ограничения "PK", а затем удалить сам столбец?
спасибо!
обновление:
dtTable.Columns.Add(new System.Data.DataColumn("PRIMARY_KEY", typeof(System.Int32)));
dtTable.PrimaryKey = new DataColumn[1] { dtTable.Columns["PRIMARY_KEY"] }; // throws an error
dtTable.Columns["PRIMARY_KEY"].AutoIncrement = true;
2 ответов
вы можете удалить ключ primay, используя
DataTable.PrimaryKey = null;
вы можете удалить столбец таблицы данных с помощью
DataTable.Columns.Remove("column name here");
я обнаружил, что иногда после удаления PrimaryKey из DataTable:
MyDataTable.PrimaryKey = null;
уникальный параметр остается верным для столбцов-членов удаленной PrimaryKey.
мое решение:
public static void KillPrimaryKey(DataTable LocDataTable)
{
int LocPriKeyCount = LocDataTable.PrimaryKey.Length;
string[] PrevPriColumns = new string[LocPriKeyCount];
// 1. Store ColumnNames in a string Array
for (int ii = 0; ii < LocPriKeyCount; ii++) PrevPriColumns[ii] = LocDataTable.PrimaryKey[ii].ColumnName;
// 2. Clear PrimaryKey
LocDataTable.PrimaryKey = null;
// 3. Clear Unique settings
for (int ii = 0; ii < LocPriKeyCount; ii++) LocDataTable.Columns[PrevPriColumns[ii]].Unique = false;
}