首页 新闻 搜索 专区 学院

存储过程报错

0
悬赏园豆:15 [已关闭问题] 关闭于 2013-03-14 11:33

我想根据传入的表名查询表里相应数据,这种写法报错,请问需要怎样修改?谢谢。。。。

Create PROCEDURE ALLGetPageDataOutRowPageCount
(
@PageIndex int = 1,--当前页数 
@PageSize  int = 4,--每页大小
@NowPage   int = 1,--根据传入栏目id要加载当前页的数据
@NowTable  NVARCHAR(50) = N'table',--当前传入表名
@RowCount int output,--总行数(传出参数)
@PageCount int output--总页数(传出参数)
)
AS
begin
        DECLARE @sql NVARCHAR(max),@sqlCount NVARCHAR(225)
        select @RowCount =COUNT(FChildId),@PageCount=CEILING((COUNT(FChildId)+0.0)/@PageSize) FROM @NowTable where FParentsId=@NowPage
        SET @sql='SELECT TOP '+LTRIM(str(@PageSize))+' * FROM '+@NowTable+' where FParentsId='+LTRIM(str(@NowPage))+' and FChildId not in(select top '+LTRIM(str((@PageIndex-1)*@PageSize))+' FChildId from '+@NowTable+' where FParentsId='+LTRIM(str(@NowPage))+' order by FImagIndex desc,FImageUpTime desc)order by FImagIndex desc, FImageUpTime desc'
        print @sql
        EXEC(@sql)
end

报错为{消息 1087,级别 15,状态 2,过程 ALLGetPageDataOutRowPageCount,第 13 行
必须声明表变量 "@NowTable"。}

~峰~的主页 ~峰~ | 初学一级 | 园豆:120
提问于:2013-03-04 11:27
< >
分享
所有回答(3)
0

是说你这句也要使用EXEC执行吧。

select @RowCount =COUNT(FChildId),@PageCount=CEILING((COUNT(FChildId)+0.0)/@PageSize) FROM @NowTable where FParentsId=@NowPage

比如

Set @sql1='select @RowCount =COUNT(FChildId),@PageCount=CEILING((COUNT(FChildId)+0.0)/@PageSize) FROM '+@NowTable+' where FParentsId=@NowPage';

EXEC(@sql1);

滴答的雨 | 园豆:3690 (老鸟四级) | 2013-03-04 11:45

这样写我怎么给@RowCount 赋值呢?难道只能用字符串拼接??谢谢。。。

支持(0) 反对(0) ~峰~ | 园豆:120 (初学一级) | 2013-03-04 12:07

@~峰~:

拼接  或者  参考下面示例:

CREATE PROCEDURE PROC_Login_executesql(
@userNamenvarchar(10),
@password nvarchar(10),
@count int OUTPUT
)
AS
BEGIN
   DECLARE @s nvarchar(1000);
set @s=N'SELECT @count=COUNT(*) FROM Login WHERE UserName=@userName AND Password=@password';
   EXEC sp_executesql @s,N'@userName nvarchar(10),@password nvarchar(10),@count int output',@userName=@userName,@password=@password,@count=@count output
END
支持(1) 反对(0) 滴答的雨 | 园豆:3690 (老鸟四级) | 2013-03-04 15:17
0

exec sp_executesql @sql,N'@RowCount int OUT',@RowCount OUT 

Rich.T | 园豆:3440 (老鸟四级) | 2013-03-04 13:52
0

 笨方法,你如果很清楚 @NowTable 的列数,假设为3列,可以用字符串拼接啊,在获取Table 后从第一行取出数据,再把第一行删除掉就是你要的数据了,这样免去了你修改参数的麻烦

Create PROCEDURE ALLGetPageDataOutRowPageCount
(
@PageIndex int = 1,--当前页数 
@PageSize int = 4,--每页大小
@NowPage int = 1,--根据传入栏目id要加载当前页的数据
@NowTable NVARCHAR(50) = N'table'--当前传入表名
)
AS
begin
DECLARE @sql NVARCHAR(max),@sqlCount NVARCHAR(225)
select @sql=' select COUNT(FChildId),CEILING((COUNT(FChildId)+0.0)/('+@PageSize+')),'''' FROM @NowTable where FParentsId=@NowPage union all SELECT TOP '+LTRIM(str(@PageSize))+' * FROM '+@NowTable+' where FParentsId='+LTRIM(str(@NowPage))+' and FChildId not in(select top '+LTRIM(str((@PageIndex-1)*@PageSize))+' FChildId from '+@NowTable+' where FParentsId='+LTRIM(str(@NowPage))+' order by FImagIndex desc,FImageUpTime desc)order by FImagIndex desc, FImageUpTime desc' EXEC sp_executesql @sql end
maanshancss | 园豆:303 (菜鸟二级) | 2013-03-05 08:42
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册