我在我的datagridview中添加了一个查找组合框。任何更改为现有行或添加新行都会将RowState中的值更改为“已修改”或“已添加”。除了改变组合框中的值。在保存时,RowState保持未修改状态。
我用来添加组合框的代码是。
DataGridViewComboBoxColumn cbQualification = new DataGridViewComboBoxColumn();
cbQualification.HeaderText = "Course Code";
DataSet myDataSet = GetData.GetCoursesData();
cbQualification.DataSource = myDataSet.Tables[0];
cbQualification.DisplayMember = "Code";
cbQualification.ValueMember = "ID";
cbQualification.DataPropertyName = "QualID";
grdPersonQuals.Columns.Insert (1,cbQualification);
save事件使用代码。
grdPersonQuals.BindingContext[grdPersonQuals.DataSource, grdPersonQuals.DataMember].EndCurrentEdit();
foreach (DataRow row in dsPersonQuals.Tables[0].Rows)
{
object x = row.RowState;
}
答案 0 :(得分:1)
我猜你的保存按钮时焦点仍在你的组合框列中?我总是调用DataGridView的EndEdit方法来触发更新数据源。
所以在你的保存按钮事件中
grdPersonQuals.EndEdit();
您在绑定上下文中调用它,但我相信您需要在网格本身上调用它,以便将网格中的更改推送到它的数据源。
答案 1 :(得分:0)
如果未修改,可以设置rowstate
foreach (DataRow row in dsPersonQuals.Tables[0].Rows)
{
row.SetAdded(); // or row.SetModified();
object x = row.RowState;
}