2

特定の行でデータベースを更新しようとすると、エラーが発生しますMust declare scalar variable "@lvl"。私が何をすべきかよくわかりません。SQL ステートメント内で値を宣言する必要がありますか?

private void button1_Click(object sender, EventArgs e)
{
    GridViewCellInfo grd = (GridViewCellInfo)radGridView1.Rows[0].Cells[0];
    string lvl = grd.Value.ToString(); 

    string sqlPatientCmd =
        @"UPDATE MotorTB
          SET RightColumn = @RightColumnCB, LeftColumn =  @leftColumnCB
          WHERE (Level = @lvl)";
    SqlConnection connString = new SqlConnection(@"Data Source=MERCURY\SQLEXPRESS;Initial Catalog=AsiaDB; Integrated Security=SSPI;User ID=MERCURY\Sophie;");
    try {
        connString.Open();

        SqlCommand sqlCmdStatement = new SqlCommand(sqlPatientCmd, connString);

        GridViewCellInfo grid;
        grid = (GridViewCellInfo)radGridView1.Rows[0].Cells[1];
        string rightColVal = grid.Value.ToString();

        grid = (GridViewCellInfo)radGridView1.Rows[0].Cells[2];
        string leftColVal = grid.Value.ToString();

        sqlCmdStatement.Parameters.AddWithValue("@rightColumnCB", rightColVal);
        sqlCmdStatement.Parameters.AddWithValue("@leftColumnCB", leftColVal);
        sqlCmdStatement.ExecuteScalar();
    } catch (Exception ex) {
        Console.WriteLine(ex.ToString());
    }

    // Close the connection
    try {
        connString.Close();
    } catch (Exception ex) {
        Console.WriteLine(ex.ToString());
    }
}
4

2 に答える 2

2

lvl 変数を SqlParamter として追加する必要があります

sqlCmdStatement.Parameters.AddWithValue("@lvl", lvl);
于 2012-04-22T14:33:02.453 に答える
1

@lvl は、パラメーターとして指定するか、クエリで定義する必要があります。

于 2012-04-22T14:33:21.067 に答える