存储过程求高人!~~~~总是进入死循环

qqwwa1 2012-11-30 04:05:59
我是一个小白,刚开始学习。写了一个存储过程总是进入死循环。求帮忙


BEGIN
declare leftId varchar(32);/* 声明变量:左边安置的id*/
declare rightId varchar(32);/* 声明变量:右边边安置的id*/
declare nextId varchar(32);/* 声明变量:父级id*/

set nextId=shop_in_id;
set leftId = '0';
set rightId='0';


/* addTO 循环 开始*/
lop1:loop

select id into leftId from member where leftPartition_id =nextId;/* 获得 父级 左边 id 分区*/
if leftId is not null then
update member set leftPartitionNumber = leftPartitionNumber+1 where id=leftId;/* 获得 父级 左边 分区数+1*/
else
set leftId = '0';
select id into rightId from member where rightPartition_id = nextId;/* 获得 父级 右边 id 分区*/
if rightId is not null then
update member set rightPartitionNumber =rightPartitionNumber+1 where id=rightId;/* 获得 父级 右边 分区数+1*/

else
set rightId='0';
end if;
end if;


if leftId !='0' then
set nextId=leftId;
end if;

if rightId !='0' then
set nextId=rightId;
end if;

if rightId = '0' and leftId ='0' then
leave lop1;/* addTO 循环 跳出结束*/
end if;

end loop;
END
...全文
181 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
qqwwa1 2012-12-04
  • 打赏
  • 举报
回复
表示问题解决了。分送给版主吧,个人感觉可能是变了传递的时候和自己想的不一样,本初想弄成递归,希望高人指点。我继续研究下。本人纯自学希望高手帮忙 BEGIN declare leftId varchar(32);/* 声明变量:左边安置的id*/ declare rightId varchar(32);/* 声明变量:右边边安置的id*/ declare nextId varchar(32);/* 声明变量:父级id*/ set nextId=shop_in_id; /* addTO 循环 开始*/ addTO:loop if exists (select id from member where leftPartition_id =nextId) then select id into leftId from member where leftPartition_id =nextId;/* 获得 父级 左边 id 分区*/ set nextId=leftId; update member set leftPartitionNumber = leftPartitionNumber+1 where id=leftId;/* 获得 父级 左边 分区数+1*/ else if (select id from member where rightPartition_id =nextId) then select id into rightId from member where rightPartition_id = nextId;/* 获得 父级 右边 id 分区*/ set nextId=rightId; update member set rightPartitionNumber =rightPartitionNumber+1 where id=rightId;/* 获得 父级 右边 分区数+1*/ else leave addTO;/* addTO 循环 跳出结束*/ end if; end if; end loop; END
qqwwa1 2012-12-04
  • 打赏
  • 举报
回复
我这个 是怎么错了啊?
ACMAIN_CHM 2012-11-30
  • 打赏
  • 举报
回复
建议参考一下手册中的写法,使用handler CREATE PROCEDURE curdemo() BEGIN DECLARE done INT DEFAULT 0; DECLARE a CHAR(16); DECLARE b,c INT; DECLARE cur1 CURSOR FOR SELECT id,data FROM test.t1; DECLARE cur2 CURSOR FOR SELECT i FROM test.t2; DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1; OPEN cur1; OPEN cur2; REPEAT FETCH cur1 INTO a, b; FETCH cur2 INTO c; IF NOT done THEN IF b < c THEN INSERT INTO test.t3 VALUES (a,b); ELSE INSERT INTO test.t3 VALUES (a,c); END IF; END IF; UNTIL done END REPEAT; CLOSE cur1; CLOSE cur2; END
qqwwa1 2012-11-30
  • 打赏
  • 举报
回复
help^~~~~~~~~~~~~~~~~~~
qqwwa1 2012-11-30
  • 打赏
  • 举报
回复
各种方法都使了,不知道怎么解决啊。求高人指点下就行。
qqwwa1 2012-11-30
  • 打赏
  • 举报
回复
……等人啊啊啊。啊啊啊啊啊啊啊啊 啊啊啊啊啊 啊啊啊 啊啊啊啊啊啊啊 啊 啊啊啊啊 啊啊 啊啊啊
内容概要:本文围绕可变桨叶四旋翼无人机的规范控制与点对点运动模拟展开,重点研究优化推力分配策略在翻转动作中的应用与性能比较。通过Matlab代码实现,构建了四旋翼动力学模型,并设计了多种控制算法以实现精确的姿态调整与轨迹跟踪。研究对比了不同推力分配方案在执行高机动性翻转动作时的稳定性、能耗效率与响应速度,旨在提升无人机在复杂飞行任务中的动态性能与控制精度。该仿真研究为无人机飞控系统的设计与优化提供了理论依据和技术支持。; 适合人群:具备一定自动控制理论基础和Matlab编程能力,从事无人机控制、飞行器动力学或机器人系统研究的科研人员及研究生。; 使用场景及目标:① 实现四旋翼无人机在三维空间中的精确点对点运动控制;② 对比分析不同推力分配策略在执行翻转等高难度动作时的控制效果与能耗表现,优化飞行性能;③ 为无人机自主飞行、特技飞行及复杂环境下的机动控制提供算法验证平台。; 阅读建议:此资源以Matlab仿真为核心,建议读者结合相关控制理论知识,深入理解代码实现细节,重点关注动力学建模、控制律设计与推力分配模块。在学习过程中,应动手调试参数,复现文中翻转动作的仿真结果,并尝试拓展至其他复杂飞行任务,以加深对无人机控制机理的理解。

57,064

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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