DataGridViewComboBoxColumn值更改不将RowState更改为已修改

时间:2012-10-29 10:01:08

标签: c# datagridview rowstate

我在我的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;
            }

2 个答案:

答案 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;
        }