このコードには「スカラー変数 @BillNo を宣言する必要があります」という問題があり、修正方法がわかりません。私はC#とプログラミングが初めてです。理解するために他のスカラー変数にコメントしましたが、まだ問題があります。スカラー変数を使用していないときにデータが挿入されますが、それらを使用する必要があります。
private void button1_Click(object sender, EventArgs e)
{
try
{
db = new DBConnection();
String Sqlstr1 = "select UnitPrice from AItem where ItemID = '" + tbItemID.Text + "'";
db.DataRead(Sqlstr1);
int UnitPrice = Convert.ToInt32(db.dr["UnitPrice"]);
int qty = Convert.ToInt32(tbQuantity.Text);
int sum = (UnitPrice * qty);
String fday = Convert.ToString(db.now.AddDays(7));
int billno = DateTime.Now.DayOfYear;
String Sqlstr3 = "insert into Sales (ItemID ,BillNo ,Qty ,Sum, FinalDay) values ('" + tbItemID.Text + "' ,@BillNo,'" + qty + "' ,'" + sum + "' ,'" + fday + "' )";
//db.cmd.Parameters.AddWithValue("@ItemID", tbItemID.Text);
db.cmd.Parameters.AddWithValue("@BillNo" , billno);
//db.cmd.Parameters.AddWithValue("@Qty", tbQuantity.Text);
//db.cmd.Parameters.AddWithValue("@Sum", (UnitPrice * qty));
//db.cmd.Parameters.AddWithValue("@FinalDay", db.now.AddDays(7));
if (db.Execute(Sqlstr3) == 1)
{
MessageBox.Show("added");
}
else
{
MessageBox.Show("something went wrong");
}
}
catch (SqlException m)
{
MessageBox.Show(m.Message);
}
catch (NullReferenceException m)
{
MessageBox.Show(m.Message);
}
catch (InvalidOperationException m)
{
MessageBox.Show(m.Message);
}
}
}