0

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

保存事件使用代码。

 grdPersonQuals.BindingContext[grdPersonQuals.DataSource, grdPersonQuals.DataMember].EndCurrentEdit();
            foreach (DataRow row in dsPersonQuals.Tables[0].Rows)
            {
                object x = row.RowState;
            }
4

2 回答 2

1

我猜点击保存按钮时焦点仍然在您的组合框列中?我一直调用 DataGridView 的 EndEdit 方法来触发更新数据源。

所以在你的保存按钮事件中

grdPersonQuals.EndEdit();

您在绑定上下文中调用它,但我相信您需要在网格本身上调用它,以便将网格中的更改推送到它的数据源。

于 2012-10-30T13:18:35.567 回答
0

如果未修改,您可以设置行状态

    foreach (DataRow row in dsPersonQuals.Tables[0].Rows)
        {
            row.SetAdded(); // or row.SetModified();
            object x = row.RowState;
        }
于 2012-10-29T11:21:57.197 回答