mysql存储过程参数带有逗号问题
我mysql存储过程的参数带有逗号,比如1,2,3想直接传入这个用wherein删除这三个编码的数据,可在存储执行后,只有1删除了,我觉得是不是参数不能有逗号的原因,请问...
我mysql存储过程的参数带有逗号,比如1,2,3想直接传入这个用where in删除这三个编码的数据,可在存储执行后,只有1删除了,我觉得是不是参数不能有逗号的原因,请问这个怎么来处理,如果替换后,再存储过程中怎么替换回来
展开
2个回答
展开全部
这个应该可以使用字符串拼接,你是不是这样写存储过程:
create procedure p_proc(var_in int)
begin
delete from [tableName] where [colName] in (var_in);
end
然后又这样调用:
call p_proc(1, 2, 3);
这样肯定不行,那么你可以这样:
create procedure p_proc(var_in varchar(5000))
begin
set @sql = concat("delete from [tableName] where [colName] in (", var_in, ")");
prepare stmt_exe_sql from @sql;
execute stmt_exe_sql;
deallocate prepare stmt_exe_sql;
end
这样就相当于把(1, 2, 3)拼接成语句"delete from [tableName] where [colName] in (1, 2, 3)", 然后执行,就可以删除了。
create procedure p_proc(var_in int)
begin
delete from [tableName] where [colName] in (var_in);
end
然后又这样调用:
call p_proc(1, 2, 3);
这样肯定不行,那么你可以这样:
create procedure p_proc(var_in varchar(5000))
begin
set @sql = concat("delete from [tableName] where [colName] in (", var_in, ")");
prepare stmt_exe_sql from @sql;
execute stmt_exe_sql;
deallocate prepare stmt_exe_sql;
end
这样就相当于把(1, 2, 3)拼接成语句"delete from [tableName] where [colName] in (1, 2, 3)", 然后执行,就可以删除了。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询