提前感谢任何帮助或建议。
我在这里发现了许多与我的问题相关的帖子,但我正在努力找出我需要改变什么来解决我从C#应用程序更新MS Access数据库的问题。如果人们觉得这篇文章与其他帖子太相似,我很抱歉。
这是我的更新代码:
OleDbConnection conn = new OleDbConnection();
conn.ConnectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=\\DATA2\Nescot Students\Y13\s0234438\dboCanada.accdb";
conn.Open();
string query = "UPDATE Products SET [Product_Name] = @ProName, [Product_Description] = @ProDes, [Standard_Cost] = @StaCos, [Category] = @Cat, [List_Price] = @LisPri WHERE ID = '" + Convert.ToInt16(lblID.Text) + "'";
OleDbCommand cmd = new OleDbCommand(query, conn) /*{ CommandType = CommandType.Text }*/;
cmd.Parameters.AddWithValue("@ProName", txtProducts.Text);
cmd.Parameters.AddWithValue("@ProDes", txtDescription.Text);
cmd.Parameters.AddWithValue("@StaCos", Convert.ToDecimal(txtPrice.Text));
cmd.Parameters.AddWithValue("@Cat", txtCat.Text);
cmd.Parameters.AddWithValue("@LisPri", Convert.ToDecimal(txtListPrice.Text));
int rowsAffected = cmd.ExecuteNonQuery();
conn.Close();
我确信我非常接近让这个工作,但我不知道从哪里开始......即将出现的错误是
'标准表达式中的数据类型不匹配。'
答案 0 :(得分:4)
WHERE ID = '" + Convert.ToInt16(lblID.Text) + "'"
这是错误的。如果您的ID
列是数字,则不需要使用单引号。
为什么不将它作为参数添加,因为你为其他人做了?等;
..WHERE ID = @id;
cmd.Parameters.AddWithValue("@id", Convert.ToInt32(lblID.Text));
还可以使用using
statement来处置您的OleDbConnection
和OleDbCommand
。
string ConnString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=\\DATA2\Nescot Students\Y13\s0234438\dboCanada.accdb";
using(OleDbConnection conn = new OleDbConnection(ConnString ))
using(OleDbCommand cmd = conn.CreateCommand())
{
cmd.CommandText = @"UPDATE Products SET [Product_Name] = @ProName, [Product_Description] = @ProDes, [Standard_Cost] = @StaCos, [Category] = @Cat, [List_Price] = @LisPri WHERE ID = @id";
cmd.Parameters.AddWithValue("@ProName", txtProducts.Text);
cmd.Parameters.AddWithValue("@ProDes", txtDescription.Text);
cmd.Parameters.AddWithValue("@StaCos", Convert.ToDecimal(txtPrice.Text));
cmd.Parameters.AddWithValue("@Cat", txtCat.Text);
cmd.Parameters.AddWithValue("@LisPri", Convert.ToDecimal(txtListPrice.Text));
cmd.Parameters.AddWithValue("@id", Convert.ToInt32(lblID.Text));
conn.Open();
int rowsAffected = cmd.ExecuteNonQuery();
conn.Close();
}