0

初めてデータグリッドをデータベースに保存します。助けてくれてありがとう。
私はこの方法でdataGridを埋めます:

 private void FillGrid1()
    {
        frmEditovat frm2 = new frmEditovat(this);
        DataTable DT = null;
        DataRow newRow;
        int pTypNastaveniaID = 0;
        string pNazov = "", pHodnota = "";

        DataConnector_My dataConnector = new DataConnector_My(mDataRoot.ConnectCentrum.ConnectionString);


        try
        {
            dataConnector.Init(mDataRoot.ConnectCentrum);

            DT = dataConnector.Get_Nastavenia();

            /* Odstranim zdroj pre Grid. Musi byt koli triedeniu gridu. */
            dataGridView1.DataSource = null;
            /* Smazanie Tabulky. */
            mDTable1.Clear();

            for (int row = 0; row < DT.Rows.Count; row++)
            {
                pTypNastaveniaID = 0; pNazov = ""; pHodnota = "";

                if (DT.Rows[row]["TypNastaveniaID"] != DBNull.Value) pTypNastaveniaID = Convert.ToInt32(DT.Rows[row]["TypNastaveniaID"]);
                if (DT.Rows[row]["Nazov"] != DBNull.Value) pNazov = DT.Rows[row]["Nazov"].ToString();
                if (DT.Rows[row]["Hodnota"] != DBNull.Value) pHodnota = DT.Rows[row]["Hodnota"].ToString();

                newRow = mDTable1.NewRow();

                newRow["TypNastaveniaID"] = pTypNastaveniaID;
                newRow["Nazov"] = pNazov;
                newRow["Hodnota"] = pHodnota;


                mDTable1.Rows.Add(newRow);
            }


            /* Datovy zdroj zpet. */
            dataGridView1.DataSource = mDTable1;

            Application.DoEvents();
        }
        catch (SqlException e)
        {
            MessageBox.Show(this.GetType() + ".FillGrid: " + Environment.NewLine + e.Message, "ERROR", MessageBoxButtons.OK, MessageBoxIcon.Error);
        }
        finally
        {
            DT.Dispose();
        }

    }

ボタンのアクションをクリックした後、datagriView1をデータベースに保存したい:

  private void btnSave_Click_1(object sender, EventArgs e)

または、同様のコードを使用した例をいただければ幸いです。

4

1 に答える 1

3

TableAdapters を使用しているかどうかを指定しなかったので、Datatable に固執していると思います...

最も簡単な方法は、最初に変更を探してから、それらを反復処理することです。その性質 (NEW、UPDATE、DELETED) に従って、データベースに対して独自のクエリを実行します。

var dataTable = ((DataTable)dataGridView1.DataSource).GetChanges();
if(dataTable != null && dataTable.Rows.Count > 0)
{
  foreach (DataRow row in dataTable.Rows)
        {
            switch (row.RowState)
            {
                case DataRowState.Added:
                    // DO INSERT QUERY
                    break;
                case DataRowState.Deleted:
                    // DO DELETE QUERY
                    break;
                case DataRowState.Modified:
                    SqlCommand command = new SqlCommand("UPDATE YOURTABLE SET TypNastaveniaID = @typ, Nazov = @title, Hodnota = @amount");
                    command.Parameters.Add(new SqlParameter("@typ", row["TypNastaveniaID"]));
                    command.Parameters.Add(new SqlParameter("@title", row["Nazov"]));
                    command.Parameters.Add(new SqlParameter("@amount", row["Hodnota"]));
                    command.ExecuteNonQuery();
                    break;
            }
        }
    ((DataTable)dataGridView1.DataSource).AcceptChanges();
}

アイデアが得られることを願っています。ルート テーブルで呼び出す必要がある AcceptChanges に注意してください。変更が「DONE」に設定されるため、次にクリックしたときに同じ行を再度繰り返すことはありません。

于 2013-08-03T06:53:35.143 に答える