Проблема c#: Как сохранить изменения, внесенные в DataGridView, обратно в используемый DataTable?
Я получаю DataTable из DataSet, а затем привязываю этот DataTable к DataGridView. Как только пользователь редактирует информацию о DataGridView, как я могу принять эти изменения и вернуть их в DataTable, который был использован, чтобы я мог вернуть в свой набор данных?
Я хочу сделать кнопку сохранения на моем DataGrid, которая при нажатии фактически сохраняет изменения.
Я не могу, если я могу получить больше конкретных, чем это, потому что это довольно просто вопрос.
спасибо заранее!
Дайте мне знать, если вам нужно, чтобы я более сложное.
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);
}
}
}
Как уже упоминалось DataAdapters являются одним из простых способов.
посмотреть: http://www.codeproject.com/KB/database/relationaladonet.aspx
для довольно простого примера, который, я думаю, охватывает то, что вам нужно.