您的位置:首页 > 数据库

sql 在将 nvarchar 值 转换成数据类型 int 时失败。

2016-07-07 11:13 2021 查看
假设有存储过程:proc_test2

create proc proc_test2

@Id int

begin

as

declare @sql varchar(max)

@sql = 'select * from test2 where 1=1'

if @Id <> 0

set @sql += ' and Id = ' +@Id

exec (@sql)

end

存储过程需要的参数是int类型,按道理直接传值(+@Id)是没有问题的,但是在执行存储过程的时候,却弹出

“sql 在将 nvarchar 值 转换成数据类型 int 时失败。”

这时候你需要转换一下就ok了!

正解是:set @sql += ' and Id = ' +Cast([b]@Id as nvarchar(50))[/b]
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: