高分求解: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"。
求高手给合理解释。
我知道我这个有问题,我是想知道,就我现在的这个存储过程应该怎么改呢? 展开
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"。
求高手给合理解释。
我知道我这个有问题,我是想知道,就我现在的这个存储过程应该怎么改呢? 展开
2个回答
展开全部
exec('select @totalCount = count(['+ @orderByWhere +']) from '+ @pageTable +' where '+ @pageWhere)
你count 直接count(*) 就可以了...
网上Demo很多你找一个直接用多好
你count 直接count(*) 就可以了...
网上Demo很多你找一个直接用多好
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询