mysql存储过程一个参数有多个逗号分割

 我来答
Cs73hv5
2017-04-20 · 超过12用户采纳过TA的回答
知道答主
回答量:45
采纳率:0%
帮助的人:23.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)", 然后执行,就可以删除了。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
粽叶金龙星3742
2017-04-20 · TA获得超过269个赞
知道小有建树答主
回答量:552
采纳率:0%
帮助的人:276万
展开全部
这个应该可以使用字符串拼接,你是不是这样写存储过程: create procedure p_proc(var_in int) begin delete from [tableName] where [colName] in (var_in); end 然后又这样调用: call p_proc(1, 2, 3); 这样肯定不行,那么你可以这样:
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式