帮我看看这个存储过程哪里错了

fjlh 2006-02-26 09:33:53
CREATE PROCEDURE user_readInfo
@uid int,
@page int,
@rsCount int output,
@pageSum int output
AS
declare @pageSize int,
@topSize int
select @pageSize=20
select @topSize=@pageSize*(@page-1)
SELECT @rsCount=count(id) FROM userInfo where uid=@uid
if @@error<>0 or @@rowcount=0
begin
return @@error
end
select @pageSum=ceiling( @rsCount/@pageSize)
if(@page=1)
begin
exec('SELECT TOP '+ @pageSize+' * FROM userInfo where uid='+@uid+' order by id desc')
return @@error
end
exec('SELECT TOP '+ @pageSize+' * FROM userInfo
WHERE (id <(SELECT MIN(id) FROM (SELECT TOP '+@topSize+' id FROM userInfo where uid='+@uid+'
ORDER BY id DESC) DERIVEDTBL)) and uid=@uid ORDER BY id DESC')
return @@error
GO
这个存储过程可以得到记录集,但是得到的页数(@pageSum)和记录的条数(@rsCount)都是0,各位高手帮我看看哪里出错了,
...全文
203 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
fjlh 2006-02-27
  • 打赏
  • 举报
回复
我这样调用存储过程的
fjlh 2006-02-27
  • 打赏
  • 举报
回复
SqlCommand comm1=db.getCMD("user_readInfo");
comm1.Parameters.Add("@uid",SqlDbType.Int);
comm1.Parameters["@uid"].Value=uid;
comm1.Parameters.Add("@page",SqlDbType.Int);
comm1.Parameters["@page"].Value=page;
comm1.Parameters.Add("@rsCount",SqlDbType.Int);
comm1.Parameters["@rsCount"].Direction=ParameterDirection.Output;
comm1.Parameters.Add("@pageSum",SqlDbType.Int);
comm1.Parameters["@pageSum"].Direction=ParameterDirection.Output;
comm1.Parameters.Add("@RETURN_VALUE",SqlDbType.Int,4);
comm1.Parameters["@RETURN_VALUE"].Direction =ParameterDirection.ReturnValue;
SqlDataReader thisRead=comm1.ExecuteReader();
fjlh 2006-02-27
  • 打赏
  • 举报
回复
我是C#调用的
bugchen888 2006-02-27
  • 打赏
  • 举报
回复
把你的调用方法贴出来看看,另外,你这样的写法是不能return出@@error的,因为在if判断之后@@error就被清空了。

if @@error<>0 or @@rowcount=0
begin
return @@error
end
wgsasd311 2006-02-27
  • 打赏
  • 举报
回复
--你是怎样调用此存储过程的?
--try
declare @uid int,
@page int,
@rsCount int ,
@pageSum int
select @uid=1,@page=2
exec user_readInfo @uid,@page,@rscount output,@pagesum output
select @rscount,@pagesum
fjlh 2006-02-26
  • 打赏
  • 举报
回复
我就是@@error<>0 or @@rowcount=0就都不要执行下面的程序了
我可以得到记录集,
说明还是运行下面的程序了
但是得到的页数(@pageSum)和记录的条数(@rsCount)都是0
Andy__Huang 2006-02-26
  • 打赏
  • 举报
回复
if @@error<>0 or @@rowcount=0
begin
return @@error
end

這個判斷有問題,如果@@rowcount=0並不意味著有錯誤,你的if語句應該把後面的表達分開出來才清楚一些

内容概要:本文围绕基于Basisformer模型的时间序列锂离子电池SOC(State of Charge,荷电状态)预测展开研究,利用PyTorch框架实现深度学习模型的构建与训练。通过将历史充放电数据作为输入,Basisformer能够有效捕捉电池状态的动态变化特征,提升SOC预测精度。文中详细介绍了模型结构设计、数据预处理流程、训练策略及实验结果分析,并与传统方法进行对比,验证了该方法在复杂工况下的优越性与鲁棒性。该研究不仅展示了Basisformer在时序建模中的潜力,也为电池管理系统提供了高精度的状态估计解决方案。; 适合人群:具备一定Python编程基础和深度学习理论知识,熟悉PyTorch框架,从事电池管理系统、新能源汽车或智能预测方向研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于电动汽车、储能系统等领域的电池SOC高精度实时估算;②为电池健康管理(BMS)提供可靠的状态输入;③推动深度学习在时间序列预测中的实际落地,提升现有预测模型的泛化能力与稳定性; 阅读建议:建议读者结合标题为【锂电池SOC估计】【PyTorch】基于Basisformer时间序列锂离子电池SOC预测研究(python代码实现)的资源,重点研读所提供的Python代码,深入理解数据处理方式与模型网络结构的设计思路,尝试调整超参数以观察对预测性能的影响,从而全面掌握Basisformer在时序建模中的优势、适用边界及工程化实现路径。

27,581

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧