sql l关于删除多条数据,用存储过程的问题

stringsql="deletefromUserswhere[UserId]in("+idStr+")";idStr="11,12,13,14,15";没有问题可以执行... string sql=" delete from Users where [UserId] in ("+idStr+")";idStr="11,12,13,14,15";没有问题可以执行。
但是用存储过程的时候
create proc [dbo].[P_xw_DeleteUserByIdStr]
@idStr nvarchar(50)
as
delete from Users where [UserId] in (@idStr)
这样调用
[P_xw_DeleteUserByIdStr] '11,12,13,14,15'
就会出现“在将 nvarchar 值 '20,21' 转换成数据类型 int 时失败。”
这是怎么回事,数据库默认就会把idStr转换成Int型,怎么解决。
展开
 我来答
zly0304302
2012-01-30 · TA获得超过2462个赞
知道小有建树答主
回答量:744
采纳率:0%
帮助的人:604万
展开全部
create proc [dbo].[P_xw_DeleteUserByIdStr]
@idStr nvarchar(50)
as
BEGIN
declare @sql varchar(1000)
set @sql='delete from Users where [UserId] in (' +@idStr+')'
exec(@sql)
END
今至电子科技有限公司
2024-08-23 广告
数据库备份是确保数据安全与业务连续性的关键环节。我们上海今至电子科技有限公司高度重视数据保护,定期执行全面的数据库备份策略。这包括使用先进工具和技术,对关键业务数据进行自动化备份,并存储在安全可靠的外部存储介质或云端。通过定期验证备份的完整... 点击进入详情页
本回答由今至电子科技有限公司提供
二牛资讯
2012-01-30 · TA获得超过736个赞
知道小有建树答主
回答量:631
采纳率:50%
帮助的人:566万
展开全部
需要用动态sql来处理,1楼正解。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
838
2012-01-30 · TA获得超过366个赞
知道小有建树答主
回答量:188
采纳率:0%
帮助的人:218万
展开全部
楼上正解!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式