0

我搜索了一些帖子,但仍然无法正常工作。

我有一个用 C# 编写的窗口应用程序,在这里我将 datagridview 绑定到我的数据库:

public static DataSet GetDataSet(string sql)
    {
        using (SqlConnection cn = new SqlConnection(constr))
        {
            SqlDataAdapter da = new SqlDataAdapter(sql, cn);
            DataSet ds = new DataSet();
            da.Fill(ds);
            return ds;

        }
    }

我将datagridview绑定在另一个类中:

string sql = "select Amount, Price, Description from myTable";
ds = DbHelper.GetDataSet(sql);
dataGridView2.DataSource = ds.Tables[0];

我创建了一个按钮供用户在编辑 datagridview 后更新数据库:

string sql = "select Amount, Price, Description from myTable";
DbHelper.UpdateDataSet(sql, ds);
MessageBox.Show("done");

public static void UpdateDataSet(string sql, DataSet ds)
    {
        using (SqlConnection cn = new SqlConnection(constr))
        {
            SqlDataAdapter da = new SqlDataAdapter(sql, cn);
            da.Update(ds);
        }
    }

这是错误,发生在以下行da.Update(ds);

当传递带有修改行的 DataRow 集合时,更新需要有效的 UpdateCommand。

感谢帮助。

编辑 我可以让它工作:

SqlCommandBuilder commandBuilder = new SqlCommandBuilder(da);
da.UpdateCommand = commandBuilder.GetUpdateCommand();

但只有当我在 datagridview 中显示密钥时,否则:

对于不返回任何键列信息的 SelectCommand,不支持为 UpdateCommand 生成动态 SQL。

如果我不想在 datagridview 中显示密钥,如何克服这个问题?

4

1 回答 1

0

SqlCommandBuilder 需要主键来更新字段。您仍然可以将键加载到 DataGridView,但隐藏列。

于 2013-03-25T06:40:48.913 回答