0

このコードには「スカラー変数 @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);

            }
    }
}
4

1 に答える 1

0

文字列を実行するのではなく、DbCommand を実行する必要があります。まず、開いている DbConnection を使用して DbCommand を作成し、Commandtext を文字列に設定し、すべてのパラメーター (@BillNo など) を追加してから、コマンドを実行します。

于 2013-10-03T12:02:31.673 に答える