日期:2014-05-17  浏览次数:20483 次

存储过程类型转换失败
存储过程如下:

create proc proc_SetAdminPermissions
@adminId int,
@actions varchar(4000)
as
begin
declare @userIfExists int,@sql varchar(500)
select @userIfExists=COUNT(*) from adminaction where adminid=@adminId
print @userIfExists 
if(@userIfExists > 0)
begin
set @sql = 'update adminaction set actionids='+@actions +' where adminid=' +@adminId
end
else
begin
set @sql = 'insert into adminaction(adminid,actionids) values('+@adminId+','+@actions+')'
end
exec(@sql)
end


错误信息如下:
0
消息 245,级别 16,状态 1,过程 proc_SetAdminPermissions,第 15 行
在将 varchar 值 'insert into adminaction(adminid,actionids) values(' 转换成数据类型 int 时失败。
存储过程

------解决方案--------------------
try this,

create proc proc_SetAdminPermissions
@adminId int,
@actions varchar(4000)    
as
begin
    declare @userIfExists int,@sql varchar(500)
    select @userIfExists=COUNT(*) from adminaction where adminid=@adminId
    print @userIfExists 
    
    if(@userIfExists > 0)
    begin
       set @sql = 'update adminaction set actionids='''+@actions +''' where adminid='+rtrim(@adminId)
    end
    else       
    begin
       set @sql = 'insert into adminaction(adminid,actionids) values('''+@adminId+''','+rtrim(@actions)+')'
    end
    
    exec(@sql)
end

------解决方案--------------------
--actionids, adminid 字段如果不是整型,需要加引号
--拼字段串时,需要把INT转换为字符型,再相加