3

我已经在这个问题上停留了几个小时,非常感谢任何帮助。

我正在尝试做的事情:使用 OleDb 更新 2003 MS Access 数据库。
当我执行代码时会发生什么:没有错误消息,但数据库根本没有更新。0 行受影响。
编程语言:C#

额外的信息:

(1) var_workid 是一个int,是我的表的主键。
(2) f2_sub 和 f2_field 是组合框。
(3) f2_date 是一个 DateTimePicker。
(4) f2_details、f2_pacq、f2_daily、f2_area都是TextBox。
(5) 我的连接有效,我可以毫无问题地执行诸如 SELECT ... FROM ... WHERE 之类的语句。(6).NET2.0

在 MS Access 中。
work_id、account_code、field_id、pacquiao、daily、area都是数字。
细节是文本。
date_done 是日期时间

private void btn_update_Click(object sender, EventArgs e)
    {
        string update_query;
        OleDbCommand SQLCommand = new OleDbCommand();

        update_query = "UPDATE [work_done] SET [account_code]= @AccountCode, [field_id] = @FieldID, [details] = @Details, [pacquiao] = @Pacquiao,[daily] = @Daily, [date_done] = @DateDone, [area] = @Area WHERE [work_id] = @WorkID;";
        SQLCommand.CommandText = update_query;
        SQLCommand.Connection = database;

        //Parameters
        SQLCommand.Parameters.AddWithValue("@AccountCode", f2_sub.SelectedValue.ToString());
        SQLCommand.Parameters.AddWithValue("@FieldID", f2_field.SelectedValue.ToString());
        SQLCommand.Parameters.AddWithValue("@Details", f2_details.Text);
        SQLCommand.Parameters.AddWithValue("@Pacquiao", f2_pacq.Text);
        SQLCommand.Parameters.AddWithValue("@Daily", f2_daily.Text);
        SQLCommand.Parameters.AddWithValue("@DateDone", f2_date.Value.ToString());
        SQLCommand.Parameters.AddWithValue("@Area", f2_area.Text);
        SQLCommand.Parameters.AddWithValue("@WorkID", var_workid);

        SQLCommand.CommandText = update_query;
        SQLCommand.Connection = database;

        //string message = "";
        //for (int i = 0; i < SQLCommand.Parameters.Count; i++) 
        //{
        //    message += SQLCommand.Parameters[i].Value.ToString() + "\n";
        //}
        //MessageBox.Show(message);


        int response = SQLCommand.ExecuteNonQuery();

        MessageBox.Show(response + " Update successful!", "Message", MessageBoxButtons.OK, MessageBoxIcon.Information);
        this.ParentForm.refresh();
        Close();
    }
4

1 回答 1

2

我认为 OleDbCommand 不支持这样的参数(OleDbCommand.Parameters 属性):

当 CommandType 设置为 Text 时,OLE DB .NET 提供程序不支持将参数传递给 SQL 语句或由 OleDbCommand 调用的存储过程的命名参数。在这种情况下,必须使用问号 (?) 占位符。

于 2012-11-03T08:20:40.067 回答