9

DataSet から DataTable を取得し、その DataTable を DataGridView にバインドします。ユーザーが DataGridView の情報を編集したら、それらの変更を取得して、使用した DataTable に戻してから DataSet に戻すにはどうすればよいですか?

押されたときに実際に変更を保存する保存ボタンを DataGrid に作成したいと考えています。

それはかなり単純な質問なので、それ以上具体的に言えるかどうかはわかりません。

前もって感謝します!

さらに詳しく説明する必要がある場合はお知らせください。

4

2 に答える 2

6

へのデータ バインディングを使用している場合DataGridViewは、既にDataTable/を更新していますDataSet。データベースに至るまでの変更を意味する場合、それがアダプターの出番です。

次に例を示します。

using System;
using System.Data;
using System.Linq;
using System.Windows.Forms;
static class Program
{
    [STAThread]
    static void Main()
    {
        Application.EnableVisualStyles();

        DataSet set = new DataSet();
        DataTable table = set.Tables.Add("MyTable");
        table.Columns.Add("Foo", typeof(int));
        table.Columns.Add("Bar", typeof(string));

        Button btn;
        using (Form form = new Form
        {
            Text = "DataGridView binding sample",
            Controls =
            {
                new DataGridView {
                    Dock = DockStyle.Fill,
                    DataMember = "MyTable",
                    DataSource = set
                },
                (btn = new Button {
                    Dock = DockStyle.Bottom,
                    Text = "Total"
                })
            }
        })
        {
            btn.Click += delegate
            {
                form.Text = table.AsEnumerable().Sum(
                    row => row.Field<int>("Foo")).ToString();
            };
            Application.Run(form);
        }

    }
}
于 2009-02-06T12:12:42.687 に答える
0

前述のように、DataAdapters は簡単な方法の 1 つです。

参照: http://www.codeproject.com/KB/database/relationaladonet.aspx

あなたが必要とするものをカバーしていると私が思う非常に単純な例です。

于 2009-02-06T13:40:23.523 に答える