Проблема C #: как сохранить изменения, внесенные в DataGridView, обратно в используемый DataTable?

Я получаю DataTable из DataSet, а затем привязываю этот DataTable к DataGridView. Как только пользователь редактирует информацию в DataGridView, как мне принять эти изменения и вернуть их в использованный DataTable, который я затем могу вернуть в свой DataSet?

Я хочу сделать кнопку «Сохранить» в моем DataGrid, которая при нажатии на самом деле сохраняет изменения.

Я не знаю, если я могу уточнить это, потому что это довольно простой вопрос.

Заранее спасибо!

Дайте мне знать, если вам нужно, чтобы я уточнить детали.


person OneShot    schedule 06.02.2009    source источник


Ответы (2)


Если вы используете привязку данных к 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);
        }

    }
}
person Marc Gravell    schedule 06.02.2009
comment
Боже мой, ты знаешь, о чем говоришь! Не могли бы вы взглянуть на мой другой вопрос и помочь мне, кажется, вы можете быть моей единственной надеждой! stackoverflow.com/questions/518239/. Спасибо! Я посмотрю, сработает ли это для меня. - person OneShot; 06.02.2009
comment
Это ответило на мой вопрос прямо здесь. Независимо от того, какой DataTable я привязал к DataGrid, он уже изменяется. Теперь, если бы я только мог понять, как поместить этот DataTable обратно в файл Access .MDB, из которого он появился. :/ Спасибо! - person OneShot; 06.02.2009
comment
Что ж, я посмотрю, но будьте осторожны: я мало знаю о mdb или использовании DataSet в гневе. - person Marc Gravell; 06.02.2009