[英]How to insert combo box value into Access using C#
我无法向数据库输入组合框值,它说插入查询不能包含多值并在 cmd.ExecuteNonQuery 上给出错误。 帮我解决这个问题。 我只是 C# 的菜鸟
private void Button1_Click(object sender, EventArgs e)
{
try
{
OleDbConnection conn = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=E:/Films/Database/Films/FilmDB/FilmsDB.accdb");
OleDbCommand cmd = new OleDbCommand();
cmd.Connection = conn;
cmd.CommandText = "INSERT INTO Films(DVD_No,Films_1,Category_1,SubCategory_1)VALUES(@no,@f1,@cat1,@scat1)";
cmd.Parameters.AddWithValue("no", TextBox1.Text);
cmd.Parameters.AddWithValue("f1", TextBox2.Text);
cmd.Parameters.AddWithValue("cat1", ComboBox1.GetItemText(ComboBox1.SelectedItem));
cmd.Parameters.AddWithValue("scat1", ComboBox2.GetItemText(ComboBox1.SelectedItem));
//open con
conn.Open();
//exec cmd
int row = cmd.ExecuteNonQuery();
if (row == 1)
{
MessageBox.Show("Data Stored in the Database");
}
else
{
MessageBox.Show("Error");
}
//close con
conn.Close();
}
catch (Exception c)
{
MessageBox.Show("Record failed" + c.Message);
}
}
从MSDN - OleDbCommand.CommandText 属性:
当 CommandType 设置为 Text 时,OLE DB.NET 提供程序不支持用于将参数传递给 SQL 语句或由 OleDbCommand 调用的存储过程的命名参数。 在这种情况下,必须使用问号 (?) 占位符。 例如:SELECT * FROM Customers WHERE CustomerID = ? 因此,OleDbParameter 对象添加到 OleDbParameterCollection 的顺序必须直接对应于参数的问号占位符的位置。
将您的 CommandText 替换为以下内容:
cmd.CommandText = "INSERT INTO Films(DVD_No,Films_1,Category_1,SubCategory_1)VALUES(?,?,?,?)";
您已经按正确的顺序添加了参数。 祝你好运!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.