繁体   English   中英

C# 问题:如何将 DataGridView 中所做的更改保存回使用的 DataTable?

[英]C# Issue: How do I save changes made in a DataGridView back to the DataTable used?

我从 DataSet 获取 DataTable,然后将该 DataTable 绑定到 DataGridView。 一旦用户编辑了 DataGridView 上的信息,我如何进行这些更改并将它们放回使用过的 DataTable 中,然后我可以将其放回我的 DataSet 中?

我想在我的 DataGrid 上制作一个保存按钮,当按下它时实际上会保存更改。

如果我能得到比这更具体的信息,我不会,因为这是一个相当简单的问题。

提前致谢!

如果您需要我详细说明,请告诉我。

如果您正在使用数据绑定到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

一个非常简单的例子,我认为涵盖了你需要的东西。

使用 dataTable.GetChanges() 您可以将更改作为列表获取。 遍历它们,您可以应用插入/更新/删除操作。 下面是一个示例保存按钮,将更改从 DataGridView 保存到 oracle db。

我实现了插入和更新。 您也可以简单地实现删除。 另请注意,为简单起见,我假设表的第一列作为主键。 您可以更改代码以将其用于多列 pks。 表是从 ComboBox 中动态选择的。

private void button_SaveToDb_Click(object sender, EventArgs e)
    {
        using (OracleConnection conn = new OracleConnection())
        {
            conn.ConnectionString = textBox_ConString.Text;
            conn.Open();
            var dataTable = (DataTable)dataGridView1.DataSource;
            var changes = dataTable.GetChanges();
            if (changes != null)
            {
                foreach (DataRow row in changes.Rows)
                {
                    switch (row.RowState)
                    {
                        case DataRowState.Added:
                            OracleCommand command = new OracleCommand()
                            {
                                Connection = conn,
                                BindByName = true
                            };
                            var qry = $"INSERT INTO {comboBox_Tables.SelectedItem.ToString()} (";
                            StringBuilder sb = new StringBuilder();
                            int i = 0;
                            foreach (var col in row.Table.Columns)
                            {
                                sb.Append(col + ((i == row.Table.Columns.Count - 1) ? "" : ","));
                                command.Parameters.Add(new OracleParameter(col.ToString(), row.ItemArray[i]));
                                i = i + 1;
                            }
                            sb.Append(") VALUES (");
                            i = 0;
                            foreach (var col in row.Table.Columns)
                            {
                                sb.Append(":" + col + ((i == row.Table.Columns.Count - 1) ? "" : ","));
                                command.Parameters.Add(new OracleParameter(col.ToString(), row.ItemArray[i]));
                                i = i + 1;
                            }
                            sb.Append(")");
                            command.CommandText = qry + sb;
                            command.ExecuteNonQuery();
                            break;
                        case DataRowState.Deleted:
                            break;
                        case DataRowState.Modified:
                            command = new OracleCommand()
                            {
                                Connection = conn,
                                BindByName = true
                            };
                            qry = $"UPDATE {comboBox_Tables.SelectedItem.ToString()} SET ";
                            sb = new StringBuilder();
                            i = 0;
                            foreach (var col in row.Table.Columns)
                            {
                                if (i > 0)
                                {
                                    sb.Append(col + "=:" + col + ((i == row.Table.Columns.Count - 1) ? "" : ","));
                                }

                                command.Parameters.Add(new OracleParameter(col.ToString(), row.ItemArray[i]));
                                i = i + 1;
                            }
                            command.CommandText = qry + sb + $" WHERE {row.Table.Columns[0]} = :{row.Table.Columns[0]}";
                            command.ExecuteNonQuery();
                            break;
                    }
                }

                ((DataTable)dataGridView1.DataSource).AcceptChanges();
            }
        }
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM