我在ExecuteNonQuery();
上不断收到错误。我尝试了很多方法,但不知道我错在哪里。
我在SQL Server中的orderid,price,quantity,discount,order price列中使用float
数据类型。
请帮助。
string query = "Insert into dbo.orders (OrderType,Product_Name,Product_Category,Product_Quantity,Product_Price,Date,Discount) values(@txt_rdvalue,@cb_oname,@cb_ocat,@cb_oqty,@txt_oprice,@Date,@txt_disc)";
if (string.IsNullOrWhiteSpace(txt_rdvalue.Text) || string.IsNullOrWhiteSpace(cb_oname.Text) || string.IsNullOrWhiteSpace(cb_ocat.Text) || string.IsNullOrWhiteSpace(cb_oqty.Text))
{
lbl_incorrect.Text = "please fill up all the fields";
lbl_incorrect.Visible = true;
}
else
{
using (SqlConnection con = new SqlConnection(@"Data Source=.;Initial Catalog=Pizza Mania;Integrated Security=True"))
{
using (SqlCommand cmd = new SqlCommand(query, con))
{
cmd.CommandType = CommandType.Text;
cmd.Connection = con;
con.Open();
cmd.Parameters.AddWithValue("@txt_rdvalue",txt_rdvalue.Text);
cmd.Parameters.AddWithValue("@txt_orderid",txt_orderid.Text);
cmd.Parameters.AddWithValue("@cb_oname", cb_oname.SelectedText);
cmd.Parameters.AddWithValue("@cb_ocat", cb_ocat.SelectedText);
cmd.Parameters.AddWithValue("@cb_oqty", cb_oqty.SelectedValue);
cmd.Parameters.AddWithValue("@txt_oprice", (txt_oprice.Text));
cmd.Parameters.AddWithValue("@txt_disc", txt_rdvalue.Text);
cmd.Parameters.Add(new SqlParameter("@Date", dateTimePicker1.Value.Date));
cmd.ExecuteNonQuery();
MessageBox.Show("Data Inserted");
}
}
}
我收到的错误消息:
参数化查询'(@txt_rdvalue nvarchar(8),@ txt_orderid int,@ cb_oname nvarchar(40'需要参数'@cb_oqty',这是 没提供
答案 0 :(得分:1)
presenter
答案 1 :(得分:0)
您提供的 @txt_orderid (cmd.Parameters.AddWithValue("@txt_orderid",txt_orderid.Text);
)参数不存在。请再次检查您的代码。
如果是 autoincrement
coloumn,为什么要提供此内容。
此外,数据类型不匹配正在发生。