使用ado.net删除带有“in”子句的记录

时间:2014-10-07 19:32:27

标签: ado.net in-clause

下面是代码,我正在尝试使用ado.net执行。我究竟做错了什么?

    Trying to delete records using ado.net 

    private const string SqlDeleteMultiple = @"        
    DELETE FROM [Board] 
    WHERE 
    [Id] in (@Ids)
    ";

    public void DeleteMultiple(string items)
        {
            ArgumentValidator.ThrowOnNull("item", items);

            /*   var sbItems = new StringBuilder();

               sbItems.Append("'");
               sbItems.Append(items);
               sbItems.Replace(",", "','");
               sbItems.Append("'");*/


            try
            {
                using (var conn = new SqlConnection(_connectionString))
                {
                    conn.Open();
                    using (var cmd = new SqlCommand( SqlDeleteMultiple,conn))
                    {
                        cmd.Parameters.Add(new SqlParameter("@Ids", SqlDbType.VarChar) {Value = items});
                        cmd.ExecuteNonQuery();
                    }
                }
            }
            catch (Exception err)
            {
                _logger.Log(LogLevel.Error, err, "Error calling Delete");
                throw err;
            }
        }

转换varchar值时转换失败' 9,8'到数据类型int。如果我将SqlDbType更改为Int ..我得到另一个错误。

1 个答案:

答案 0 :(得分:1)

你的@Ids包含一个值列表但你只提供一个SqlParameter ...为列表中的每个值添加一个SqlParameter它应该可以工作

您还可以使用表值参数将列表传递给存储过程...但是您需要将删除语句放入存储过程并在服务器端创建用户定义类型...