c# - 值不能为空。参数名称 : dataSource. 编辑数据网格并保存到数据库

标签 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 = "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 中的值时,它都会在我单击 button1(保存按钮)后影响我的数据库。前任。如果我在更改他的名字后将 roman 作为客户,然后单击 button1,它应该会更改。但是我得到一个值不能为空错误。请有人帮忙。 T_T

*编辑:这是更新的代码

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);

        }

最佳答案

我假设您有一个名为 dsinstance 变量,并且您期望 Form3_Load 方法来填充它?这不会发生 - 因为在 Form3_Load 中你有这个:

DataSet ds = new DataSet();

这是在声明一个名为 ds 的新 local 变量,因此除非您在该方法中显式使用 this.ds,否则您不会更改 instance 变量的值。

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

ds = new DataSet();

应该可以解决这个问题。

(请注意,我强烈建议不要在 UI 线程中发出数据库请求,并且您应该为连接使用 using 语句,但这些是不同的事情。)

关于c# - 值不能为空。参数名称 : dataSource. 编辑数据网格并保存到数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8373801/

相关文章:

c# - 水平滚动条可见时如何固定DataGrid中列的宽度?

c# - WPF如何在进度条上显示文字

c# - Xamarin Forms Listview 未显示所有项目

c# - 获取发布值 (ASP.NET)

.net - 在 Visual Studio 中构建具有大量控件的 GUI

c# - 尝试以编程方式将图像添加到资源。设置图片源时出现System.ArgumentException

wpf - 使用 C# 在 WPF 中使 DataGrid 列标题可排序

c# - 预期为 "{"但发现为 ")"。在 Asp.Net MVC 5 中, block 语句必须包含在 "{"和 "}"中

c# - 项目的 Sitecore 增量发布

c# - 如何在列表框中的项目之间添加填充?