我就不信无法排序

lovingkiss 2004-10-14 06:28:03
CREATE PROC MoveSortId
@SortId int, --要处理的id --功能:动态的调整表中的排序编号
@Arrow nvarchar(10) , --移动方向,'上'表示上移,'下'表示下移
@Table nvarchar(15) --相关表名
as
declare @s nvarchar(4000)
declare @nid int

if @SortId<1 return
set @s='
select @nid='+case when @Arrow='up' then 'min(SortId)' else 'max(SortId)' end
+'from ['+@Table+']'
exec sp_executesql @s,N'@nid int',@nid
print '---问题出在这里,返回来的@nid为空---'
print @nid
print '--------'
print @SortId
print '--------'
--如果不可移动,则退出
begin
if @nid=1
if @Arrow='up' return
else
begin
if @SortId=@nid and @Arrow<>'up' return
end
end
--取得移动后的新 SortId 值
set @nid=@SortId+case when @Arrow='up' then -1 else 1 end
if @nid < 1
begin
Set @nid = 1
end


--更新 SortId
exec ('update ['+@Table+'] set SortId=case when SortId=' + @SortId + ' then ' + @nid + ' else ' + @SortId + ' end
where SortId in(' + @SortId + ' , ' + @nid + ')')
GO





--=======================================================================
我改写成了这样,目前还有的问题,就是向上可能会无限增大,因为
exec sp_executesql @s,N'@nid int',@nid
这句话里面我不明白,所以返回来的@nid并非是最大或者最小值,而是啥都没有哇

邹建,测试我用你写的和我写的都会在极限的[最大或者最小的]测试下报错,咋办呢??
...全文
194 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
Selectau_fname 2004-10-15
  • 打赏
  • 举报
回复
厉害!
内容概要:本文详细介绍了利用Simulink进行变压器开路试验的电路连接配置与仿真实现方法,重点在于通过仿真手段还原实际电力系统中变压器在空载条件下的电气特性,从而深入理解其工作原理与性能表现。文章作为电力系统仿真系列研究的一部分,系统阐述了从电路模型搭建、参数设定、仿真运行到结果分析的完整流程,突出展示了MATLAB/Simulink在电力设备建模与教学科研中的强大功能与应用价值。; 适合人群:具备电力系统基础知识,熟悉MATLAB/Simulink仿真环境,从事电气工程、自动化及相关领域的研发人员,以及高年级本科生和研究生。; 使用场景及目标:①掌握变压器开路试验的基本原理与Simulink仿真建模的具体步骤;②通过仿真实验深入理解空载电流、铁芯损耗及励磁特性等关键参数的物理意义;③为后续开展变压器短路试验、暂态过程分析以及其他电力设备的仿真研究奠定理论与实践基础。; 阅读建议:建议结合Simulink软件动手实践,逐步构建并调试电路模型,重点关注各元件参数的设置方法与测量模块的应用技巧,同时推荐参考文中提及的其他相关仿真案例进行拓展学习,以全面提升对电力系统仿真实践的整体认知与操作能力。

34,876

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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