-1

我的方法中有很多查询。根据条件,执行特定查询。每个查询都使用相同的参数。

例如:

public static void Method(param1, param2, param3)
{
   ....
   cmd.CommandType = CommandType.Text;
   if(Condition1)
   {
      cmd.CommandText = "select * from Table1 where id=@id"
      cmd.Parameters.AddWithValue("@id", param1);
      cmd.ExecuteNonQuery();

      foreach(int i in IntegerList)
      {
          ....
          cmd.CommandText = "insert into Table2(id,type,model) values(@id,@type,@model)
          cmd.Parameters.AddWithValue("@id", param1);
          cmd.ExecuteNonQuery();
          ....       
      }
   }
   else
   {
      cmd.CommandText="select * from Table3 where id = @id"
      cmd.Parameters.AddWithValue("@id", param1);   
      SqlDataAdapter da = new SqlDataAdapter();
      da.SelectCommand = cmd;
      DataSet ds = new DataSet();
      da.Fill(ds);
      cmd.Dispose();
      da.Dispose();
      ....
   }
   cmd.CommandText = "delete from Table3 where id = @id and model=@model..."
   ....

}

我的问题是,如果我@id每次需要执行不同的查询时都继续添加参数,或者在执行查询后我的参数将被删除,我会出错吗?

4

2 回答 2

1

您应该添加一个带类型的参数,然后在需要时设置其值。这将确保类型始终正确。

话虽如此,参数在执行后不会被删除,并且AddWithValue如果键已经存在,它似乎不会引发异常,这与之前的Add. 所以你应该能够再次添加参数。

当然,如果值相同并且只有查询更改,则无需再次添加。

于 2015-08-12T17:25:03.880 回答
0

首先使用所有参数准备命令对象,然后在循环中分配新值。

command.Parameters.Add("@id", SqlDbType.Int);
foreach (...) {
    command.Parameters["@id"].Value = param1; 
    command.ExecuteNonQuery();
}
于 2015-08-12T17:31:42.137 回答