Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/271.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 从datagridview更新数据库_C#_Winforms_Ado.net_Datagridview_Oledb - Fatal编程技术网

C# 从datagridview更新数据库

C# 从datagridview更新数据库,c#,winforms,ado.net,datagridview,oledb,C#,Winforms,Ado.net,Datagridview,Oledb,在使用适配器进行编辑之后,我在谷歌上搜索了很多关于将datagridview更新到数据库的信息。我参考了几个网站,它们给了我类似的例子,比如下面的一个。但是,我在我的按钮2\u单击的第一行出现了“ArgumentNullException was unhandled”错误 我是编程新手,我被教导将适配器声明为全局适配器,我做到了。为什么我仍然得到空值?任何帮助都将不胜感激。谢谢大家! DataTable dt; DataSet ds; OleDbDataAdapter objAdapter =

在使用适配器进行编辑之后,我在谷歌上搜索了很多关于将datagridview更新到数据库的信息。我参考了几个网站,它们给了我类似的例子,比如下面的一个。但是,我在我的按钮2\u单击的第一行出现了“ArgumentNullException was unhandled”错误

我是编程新手,我被教导将适配器声明为全局适配器,我做到了。为什么我仍然得到空值?任何帮助都将不胜感激。谢谢大家!

DataTable dt;
DataSet ds;
OleDbDataAdapter objAdapter = new OleDbDataAdapter();

public void button1_Click(object sender, EventArgs e)
{
    //Bind button
    string txt = textBox1.Text;

    string strOleDbConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Project.mdb";
    string strSqlStatement = string.Empty;
    strSqlStatement = "SELECT * FROM jiahe WHERE [User] = '" + txt + "'";
    OleDbConnection objConnection = new OleDbConnection(strOleDbConnectionString);
    objAdapter = new OleDbDataAdapter(strSqlStatement, objConnection);
    DataSet ds = new DataSet();
    dataGridView1.DataSource = ds;
    objAdapter.Fill(ds);

    DataTable dt = ds.Tables[0];
    dataGridView1.DataSource = dt.DefaultView;           

    try
    {
        if (dt.Rows.Count == 1)
        {
            MessageBox.Show("Record found.");
        }
        else
        {
            if (dt.Rows.Count == 0)
            {
                MessageBox.Show("Invalid input!");
            }
        }
    }
    catch
    {
        MessageBox.Show("Error!");
    }
}

private void button2_Click(object sender, EventArgs e)
{
    objAdapter.Update(ds);
    dataGridView1.DataSource = ds;
}

我认为这只是不同范围内变量之间的混淆。在第二次单击
按钮时使用的
ds
与用于填充网格的数据集不同。将它们设置为完全相同的实例,很可能会起作用

编辑

这样做应该足够写而不是写

DataSet ds = new DataSet();
dataGridView1.DataSource = ds;
objAdapter.Fill(ds);
DataTable dt = ds.Tables[0];`
这个


我遇到了相同的问题,我通过尝试以下方法解决了此问题:

DataSet ds = new DataSet();
dataGridView1.DataSource = ds;
objAdapter.Fill(ds);
dataGridView1.DataSource = ds.Tables[0];

我如何使它们成为完全相同的实例?把它变成一个全局变量不是很好吗?谢谢。现在我把它指向相同的ds。但是,我有另一个错误“InvalidOperationException未处理”。它说“当传递带有修改行的DataRow集合时,更新需要有效的UpdateCommand。”为什么更新命令无效?请帮忙@迪亚兹:您没有为适配器定义
update命令。适配器不知道对DB运行什么
sql
query来进行更新。没有魔法,也很容易,但你至少需要阅读以下链接:我现在明白了。谢谢你的耐心!
DataSet ds = new DataSet();
dataGridView1.DataSource = ds;
objAdapter.Fill(ds);
dataGridView1.DataSource = ds.Tables[0];