C# 值不能为null。参数名称:数据源。编辑Datagrid并保存到数据库

C# 值不能为null。参数名称:数据源。编辑Datagrid并保存到数据库,c#,winforms,datagrid,datagridview,editing,C#,Winforms,Datagrid,Datagridview,Editing,你好,我这里有个问题。代码如下所示 private void Form3_Load(object sender, EventArgs e) { string connectionString = "Server=localhost;" + "Database=oroderm;" + "User ID=root;" + "Password=root;" + "Pooling=false"; string query = "Se

你好,我这里有个问题。代码如下所示

private void Form3_Load(object sender, EventArgs e)
{ 
     string connectionString =
     "Server=localhost;" +
     "Database=oroderm;" +
     "User ID=root;" +
     "Password=root;" +
     "Pooling=false";
     string query = "Select * from client";
     MySqlConnection conn = new MySqlConnection(connectionString);
     MySqlDataAdapter dAdapter = new MySqlDataAdapter(query, connectionString);
     conn.Open();
     DataSet ds = new DataSet();
     MySqlCommandBuilder cBuilder = new MySqlCommandBuilder(dAdapter);

     dAdapter.Fill(ds, "client");

     BindingSource bSource = new BindingSource();
     bSource.DataSource = ds.Tables["client"];
     dataGridView2.DataSource = bSource;
}

private void button1_Click(object sender, EventArgs e)
{
     DataTable dt = ds.Tables["client"];
     this.dataGridView2.BindingContext[dt].EndCurrentEdit();
     this.da.Update(dt);
}
因此,我想要的是,每当我编辑Datagrid中的值时,单击按钮1(保存按钮)后,它将影响我的数据库。如果在我更改了roman的姓名并单击按钮1后,我将roman作为客户,则应该会更改。但是,我得到的值不能为空错误。有人能帮忙吗。图特

*编辑:这是更新的代码

private MySqlDataAdapter _da;
        private DataTable _dt;
        private DataSet _ds;

 private void Form3_Load(object sender, EventArgs e)
        {
               updateClient();
        }

public void updateClient()
        {
            string connectionString =
             "Server=localhost;" +
             "Database=oroderm;" +
             "User ID=root;" +
             "Password=root;" +
             "Pooling=false";

            string query = "select * from client";
            MySqlConnection conn = new MySqlConnection(connectionString);
            _da = new MySqlDataAdapter(query, connectionString);
            conn.Open();
            _ds = new DataSet();
            MySqlCommandBuilder cBuilder = new MySqlCommandBuilder(_da);

            _da.Fill(_ds, "client");
            BindingSource bSource = new BindingSource();
            bSource.DataSource = _ds.Tables["client"];
            dataGridView2.DataSource = bSource;
            _da.UpdateCommand = cBuilder.GetUpdateCommand();
        }

private void button1_Click(object sender, EventArgs e)
        {

            _dt = _ds.Tables["client"];
            this.dataGridView2.BindingContext[_dt].EndCurrentEdit();
            this._da.Update(_dt);

        }
我假设您有一个名为
ds
的实例变量,您希望
Form3\u Load
方法填充它?这不会发生-因为在
Form3\u Load
中,您得到了以下信息:

DataSet ds = new DataSet();
这是在声明一个名为
ds
的新局部变量,因此除非在方法中显式使用
this.ds
,否则不会更改
实例
变量的值

我有点惊讶,当你点击按钮时,你没有得到一个
NullReferenceException
,但也许你有一些代码来创建一个空的
DataSet
,并在某处为
ds
实例变量分配一个引用。无论如何,将上面显示的行更改为:

ds = new DataSet();
应该解决这个问题


(我强烈建议不要在UI线程中进行数据库请求,请注意,您的连接应该有一个
using
语句,但这是两个独立的问题。)

我已经通过为dataset、datatable和mysqladapter创建全局变量来运行代码。但是,我只能修改表的内容一次。编辑一次表后,我无法编辑该表的内容。这有什么问题?@rjtubera:我不知道,但对我来说这听起来像是一个单独的问题,需要更详细的描述和更新的代码。(顺便说一句,这些都不需要真正的全局变量。)我把更新后的代码放在上面。非常感谢你帮助我。T_T@rjtubera:不,我建议你问一个新问题。当一篇文章实际上包含了几个随时间变化的问题时,堆栈溢出就不起作用了。