高分求解:SQL存储过程输出参数必须声明标量变量问题

这是存储过程源码:createproc[dbo].[paging]@pageSizeint,--每页显示的行数@pageNumint,--当前显示第几页@pageTabl... 这是存储过程源码:
create proc [dbo].[paging]
@pageSize int, --每页显示的行数
@pageNum int, --当前显示第几页
@pageTable varchar(20), --表名
@orderByWhere varchar(20), --排序条件
@totalCount int output, --返回表总行数
@pageWhere varchar(20) = '1 = 1' --查询条件

as
exec('select @totalCount = count(['+ @orderByWhere +']) from '+ @pageTable +' where '+ @pageWhere)

if @pageNum < 1
set @pageNum = 1

set @pageNum = @pageSize * @pageNum
exec('select top ' + @pageSize + ' * from (select top ' + @pageNum + ' * from ' + @pageTable+ ' where '+ @pageWhere + ' order by '+ @orderByWhere +' desc) as a order by '+ @orderByWhere +' asc')

生成存储过程时没有问题。

执行存储过程时报:必须声明标量变量 "@totalCount"。

求高手给合理解释。
我知道我这个有问题,我是想知道,就我现在的这个存储过程应该怎么改呢?
展开
 我来答
木森耙耙
2010-08-10 · TA获得超过436个赞
知道小有建树答主
回答量:907
采纳率:0%
帮助的人:569万
展开全部
exec('select @totalCount = count(['+ @orderByWhere +']) from '+ @pageTable +' where '+ @pageWhere)

你count 直接count(*) 就可以了...
网上Demo很多你找一个直接用多好
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
chg010
2010-08-10 · TA获得超过102个赞
知道小有建树答主
回答量:116
采纳率:0%
帮助的人:109万
展开全部
因为exec() 相当于调用另一个存储过程,
在另一个存储过程中,你没有声明变量 @totalCount
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式