导航
  • 主页
  • 基础类
  • 应用实例
  • 新技术前沿

这个存储过程为什么出现“将 varchar 值 '61,62,63' 转换为数据类型为 int 的列时发生语法错误。”

Tadpole0510 2006-01-22 12:20:32
CREATE proc getallchildclass
@id int
as
begin
declare @ret varchar(8000),@level int
declare @t table(id int,level int)
set @level = 1
insert into @t select id,@level from classlist where parent=@id

while @@rowcount<>0
begin
set @level=@level+1
insert into @t
select a.id,@level
from classlist a,@t b
where a.parent=b.id and b.level=@level-1
and not exists(select 1 from @t where id=a.id)
end

set @ret=''
select @ret=@ret+','+rtrim(id) from @t order by id
set @ret=stuff(@ret,1,1,'')
return @ret
end
GO
...全文
97 点赞 收藏 5
写回复
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
OracleRoob 2006-01-22
return @ret

--这里return 后面必须是整数,你的@ret是一个整数的集合,'1,2,3...'
回复
Tadpole0510 2006-01-22
不行啊

(所影响的行数为 47 行)


(所影响的行数为 3 行)


(所影响的行数为 0 行)

服务器: 消息 245,级别 16,状态 1,过程 getallchildclass,行 25
将 varchar 值 '61,62,63' 转换为数据类型为 int 的列时发生语法错误。
回复
Tadpole0510 2006-01-22
我就想得到指定大类中所有小类(包含小类中的小类[递归])
回复
OracleRoob 2006-01-22
id为int,需要转换为字符型

select @ret=@ret+','+rtrim(id) from @t order by id

改为:

select @ret=@ret+','+rtrim(cast(id as varchar(20))) from @t order by id
回复
Tadpole0510 2006-01-22
服务器: 消息 245,级别 16,状态 1,过程 getallchildclass,行 24
@ret 我已经定义成字符型了,
为什么还有错误
回复
发动态
发帖子
MS-SQL Server
创建于2007-09-28

3.2w+

社区成员

MS-SQL Server相关内容讨论专区
申请成为版主
社区公告
暂无公告