C# Datagridview和两个组合框(相关)

C# Datagridview和两个组合框(相关),c#,datagridview,combobox,selectedindexchanged,C#,Datagridview,Combobox,Selectedindexchanged,当我单击dataGridView1_CellMouseClick cmbSehir时,我有一个Datagridview和两个组合框(相关)。文本会根据需要进行更改。但是cmbilce.Text并没有按我所希望的那样更改!。我在哪里会犯错。我希望我说清楚了。谢谢你的帮助 private void frmMusteriEkle_Load(object sender, EventArgs e) { GetSehir(); GetDatagridview();

当我单击dataGridView1_CellMouseClick cmbSehir时,我有一个Datagridview和两个组合框(相关)。文本会根据需要进行更改。但是cmbilce.Text并没有按我所希望的那样更改!。我在哪里会犯错。我希望我说清楚了。谢谢你的帮助

private void frmMusteriEkle_Load(object sender, EventArgs e)
    {


        GetSehir();
        GetDatagridview();
    }
 private void GetSehir() {
        db.connect();
        db.SqlQuery("select * from iller");
        DataTable dt = db.GeTDataTable();
        DataRow dr = dt.NewRow();
        dr["id"] = 0;
        dr["sehir"] = "Seçiniz:";
        dt.Rows.InsertAt(dr, 0);
        cmbSehir.DataSource = dt;
        cmbSehir.ValueMember = "id";
        cmbSehir.DisplayMember = "sehir";
        db.disconnect();
    }

private void cmbSehir_SelectionChangeCommitted(object sender, EventArgs e)
        {
        if (cmbSehir.SelectedIndex != 0)
            {
            db.connect();
            db.SqlQuery("select * from ilceler where il_id = ?");
            db.command.Parameters.AddWithValue("@p", cmbSehir.SelectedValue);
            DataTable dt = db.GeTDataTable();
            cmbilce.DataSource = dt;
            cmbilce.ValueMember = "id";
            cmbilce.DisplayMember = "ilceler";
            db.disconnect();
            }
        else
            {
            cmbilce.DataSource = null;
            }
        }
private void dataGridView1_CellMouseClick(object sender, DataGridViewCellMouseEventArgs e)
        {
        cmbSehir.Text = dataGridView1.Rows[e.RowIndex].Cells[4].Value.ToString();
        cmbilce.Text = dataGridView1.Rows[e.RowIndex].Cells[5].Value.ToString();
        }

在不了解
GetDatagridview
方法的作用的情况下,我将从以下行中假设

cmbSehir.Text = dataGridView1.Rows[e.RowIndex].Cells[4].Value.ToString();
cmbilce.Text = dataGridView1.Rows[e.RowIndex].Cells[5].Value.ToString();
这些组合框与第4列和第5列中包含的数据相关。如果组合框与
DataGridView
具有相同的数据源,则可以将所有三个控件绑定到相同的
DataSource
。将所有三个组件绑定到同一数据源后,单击网格中的单元格将自动更改组合框,反之亦然……更改组合框将更改网格中的选择。无需连接
CellMouseClick
SelectionChanged
事件来保持控件同步

另一个需要考虑的问题是
cmbSehir\u SelectionChangeCommitted
方法,该方法在用户每次更改
cmbSehir
组合框中的选择时都会触发。在这个方法中,代码查询数据库并设置组合框数据源。这很好,但是,您确定要在用户每次更改此选择时查询数据库并重新填充组合框吗?我猜在添加、删除或更改新数据之前,一个查询就足够了

下面的代码使用不同的
ValueMembers
将组合框的
DataSource
设置为
DataGridView
的相同数据源

DataTable AllData;
private void Form1_Load(object sender, EventArgs e) {
  AllData = GetDT();
  dataGridView1.DataSource = AllData;
  comboBox1.DataSource = AllData;
  comboBox2.DataSource = AllData;
  comboBox1.ValueMember = "sehir";
  comboBox2.ValueMember = "ilceler";
}

虽然cmbSehir是在加载表单MusteriEkle时实例化的,但只有在cmbSehir发生更改时,cmbilce才会经历类似的过程。cmbilce是否正确格式化并设置为接收其
.Text
值的更新?我做了我想做的。我调用dataGridView1\u CellMouseClick事件上的cmbilce。谢谢你的回答。我做了我想做的。我调用dataGridView1\u CellMouseClick事件上的cmbilce。谢谢你的回答。