1

簡単な質問があります。C# インターフェイス (SQL データベースに接続されている) に何かを挿入するたびに、プログラムした "Saved Data" というメッセージが表示されます (そして、データベースにデータが保存されます)。アプリケーションを閉じて、もう一度実行してください。

私のコードは次のとおりです。

private void frmCatalogoMunicipios_Load(object sender, EventArgs e)
    {
        cmd.Connection = conexion;
    }

    private void frmCatalogoMunicipios_Shown(object sender, EventArgs e)
    {
        CargaEstados();
        CargaDataGridView();
    }

    private void CargaEstados()
    {
        conexion.Open();
        txtNomMun.Focus();
        try
        {
            DataSet ds = new DataSet();
            MySqlDataAdapter da = new MySqlDataAdapter("SELECT cveestado, nombre FROM tbestados", conexion);
            da.Fill(ds, "FillDropDown");
            cbEstado.DisplayMember = "Nombre";
            cbEstado.ValueMember = "CveEstado";
            cbEstado.DataSource = ds.Tables["FillDropDown"];
            conexion.Close();
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message, Application.ProductName, MessageBoxButtons.OK, MessageBoxIcon.Error);
        }
    }

    private void CargaDataGridView()
    {
        conexion.Open();
        try
        {
            cmd.CommandText = "SELECT m.cvemunicipio, m.nombre AS NombreA, e.nombre AS NombreB FROM tbMunicipios m INNER JOIN tbEstados e ON m.CveEstado = e.CVeEstado";
            rd = cmd.ExecuteReader();
            while (rd.Read())
            {
                this.dataGridView1.Rows.Add(rd.GetValue(0), rd.GetValue(1), rd.GetValue(2));
            }
            conexion.Close();
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message, Application.ProductName, MessageBoxButtons.OK, MessageBoxIcon.Error);
        }
    }


conexion.Open();
            try
            {
                cmd.CommandText = "insert into tbmunicipios (nombre, cveestado) values ('" + txtNomMun.Text + "', '" + cbEstado.SelectedValue.ToString() + "')";
                cmd.ExecuteNonQuery();
                cmd.Clone();
                MessageBox.Show("Datos Guardados", "Mensaje");
                conexion.Close();
                Nuevo();
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message, Application.ProductName, MessageBoxButtons.OK, MessageBoxIcon.Error);
            }

編集

@Obamaが言ったように、私は自分で答えを見つけました。CargarDataGridView() を呼び出す必要がありますが、その前に dataGridView1.Rows.Clear(); ですべての行を削除しました。

したがって、私の最終的なコードは次のとおりです。

                conexion.Open();
            try
            {
                cmd.CommandText = "insert into tbmunicipios (nombre, cveestado) values ('" + txtNomMun.Text + "', '" + cbEstado.SelectedValue.ToString() + "')";
                cmd.ExecuteNonQuery();
                cmd.Clone();
                MessageBox.Show("Datos Guardados", "Mensaje");
                conexion.Close();
                dataGridView1.Rows.Clear();
                CargaDataGridView();
                Nuevo();
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message, Application.ProductName, MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
4

1 に答える 1

0

MessageBox.Show("Datos Guardados", "Mensaje"); 通話直後CargaDataGridView();

于 2013-04-20T22:58:25.120 に答える