mysql存储过程参数带有逗号问题

我mysql存储过程的参数带有逗号,比如1,2,3想直接传入这个用wherein删除这三个编码的数据,可在存储执行后,只有1删除了,我觉得是不是参数不能有逗号的原因,请问... 我mysql存储过程的参数带有逗号,比如1,2,3想直接传入这个用where in删除这三个编码的数据,可在存储执行后,只有1删除了,我觉得是不是参数不能有逗号的原因,请问这个怎么来处理,如果替换后,再存储过程中怎么替换回来 展开
 我来答
李磊_1
推荐于2016-03-18 · TA获得超过299个赞
知道小有建树答主
回答量:337
采纳率:66%
帮助的人:119万
展开全部
这个应该可以使用字符串拼接,你是不是这样写存储过程
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)", 然后执行,就可以删除了。
lmonkey
2021-02-09 · 教育领域创作者
个人认证用户
lmonkey
采纳数:69 获赞数:176

向TA提问 私信TA
展开全部

MySQL教程4 MySQL8运算符、函数、存储过程及新增数据类型 17.之创建带有IN和OUT参数的存储过程 学习猿地

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式