我有一种形式是一个CRUD,这种形式可以管理来自多个表的任何数据,如果一个表有外键CRUD找到当前表的各个列的表和列,那么在DataGridView中可以显示为复选框,文本框或组合框列从DataGridView获取DataTable
我做这一切在DataGridView填充数据之前,所以我不能用这个:
dataGridView1.DataSource = dtCurrent;
我需要的是这样的:
dtCurrent = dataGridView1.DataSource;
但只给一个空
我与ExtensionMethod试图在DataGridView:
public static DataTable ToDataTable(this DataGridView dataGridView, string tableName)
{
DataGridView dgv = dataGridView;
DataTable table = new DataTable(tableName);
// Crea las columnas
for (int iCol = 0; iCol < dgv.Columns.Count; iCol++)
{
table.Columns.Add(dgv.Columns[iCol].Name);
}
/**
* THIS DOES NOT WORK
*/
// Agrega las filas
/*for (int i = 0; i < dgv.Rows.Count; i++)
{
// Obtiene el DataBound de la fila y copia los valores de la fila
DataRowView boundRow = (DataRowView)dgv.Rows[i].DataBoundItem;
var cells = new object[boundRow.Row.ItemArray.Length];
for (int iCol = 0; iCol < boundRow.Row.ItemArray.Length; iCol++)
{
cells[iCol] = boundRow.Row.ItemArray[iCol];
}
// Agrega la fila clonada
table.Rows.Add(cells);
}*/
/* THIS WORKS BUT... */
foreach (DataGridViewRow row in dgv.Rows)
{
DataRow datarw = table.NewRow();
for (int iCol = 0; iCol < dgv.Columns.Count; iCol++)
{
datarw[iCol] = row.Cells[iCol].Value;
}
table.Rows.Add(datarw);
}
return table;
}
我用:
dtCurrent = dataGridView1.ToDataTable(dtCurrent.TableName);
代码不工作时:
int affectedUpdates = dAdapter.Update(dtCurrent);
我收到一个异常关于重复值(从西班牙语翻译):
对表请求的更改不成功,因为它们会在索引,主键或关系中创建重复值。更改包含重复数据的字段或字段中的数据,删除索引或重新定义索引以允许重复条目,然后重试。
我只需要使用数据表
类似于上面的'DataTable dataTable =(DataTable)dataGridView1.DataSource;'为我工作。 另请参阅:http://stackoverflow.com/questions/6295161/how-to-build-a-datatable-from-a-datagridview – surfmuggle 2013-02-13 21:48:07
你读过这个问题吗?在c#请 – 2017-01-09 10:52:40