mysql 存储过程 通过传入ids[]数组参数, 实现批量删除数据!

求大神解答。 存储过程,接收的参数为,保存多个id的字符串数组 ,以实现批量删除的 ,这样的存储过程怎么写?

阅读 19.9k
3 个回答

php的思路可以是这样的:

$id = [1,2,3,5,6];//传入的id数组

$delete_in = implode(",", $id);// 1,2,3,5,6

$query = ... delete where id in ( $delete_id ); //大概是这样的


create procedure sp_split_string
(
@string NVARCHAR(4000)
)
AS
BEGIN
DECLARE @object_id nvarchar(500)
DECLARE @i INT
DECLARE @len INT
print @string
IF (@string IS NULL) OR (LTRIM(@string) = '')
RETURN

WHILE CHARINDEX(',',@string) > 0
    BEGIN
        SET @len = LEN(@string)
        SET @i = CHARINDEX(',', @string)
        SET @object_id = LEFT(@string, @i-1)

        INSERT INTO a (id) VALUES (@object_id)--少做修改,改成需要的sql语句即可
        SET @string = RIGHT(@string, @len - @i)
    END
SET @object_id = @string
INSERT INTO a (id) VALUES (@object_id)--少做修改,改成需要的sql语句即可

END
go

--测试
-- select * from a
-- exec sp_split_string '102,103,105,106,107,108,200,500,306,408'
-- select * from a

为什么一定要使用存储过程呢??用循环执行Sql 不行吗???

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进