一个简单的 CURSOR 问题, CONTINUE 是什么用处。

trouble 2001-12-15 09:12:44
DECLARE PMCJOBD_CURSOR CURSOR FOR
SELECT NAME,EXET FROM EMPL
END

OPEN PMCJOBD_CURSOR
FETCH NEXT FROM PMCJOBD_CURSOR INTO
@NAME,
@EXEC
WHILE (@@FETCH_STATUS = 0)
BEGIN--游标开始

IF @EXET = 0 BEGIN
FETCH NEXT FROM PMCJOBD_CURSOR INTO
@NAME,
@EXET
CONTINUE
END

我按以上做,却进了死循环 ?
...全文
498 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
dmyb7233 2001-12-17
  • 打赏
  • 举报
回复
用while(@@fetch_status=0)页不用continue
trouble 2001-12-17
  • 打赏
  • 举报
回复

谢谢! OK 了
nashan 2001-12-15
  • 打赏
  • 举报
回复
在循环体内用到
nashan 2001-12-15
  • 打赏
  • 举报
回复
使程序跳过循环体内CONTINUE语句后面的Transact-SQL语句,而立即进行下次条件测试。
N_chow 2001-12-15
  • 打赏
  • 举报
回复
跟C語言里的Continue是一個意思。
trouble 2001-12-15
  • 打赏
  • 举报
回复


COUTINUE 这句话到什么意思? 他是做什么的,一般在哪里用他。

shinebei 2001-12-15
  • 打赏
  • 举报
回复
怎么没有看到声明@name, @exet啊

同意楼上说法,又是IF又是COUTINUE,有了IF怎么可以没有ELSE呢,如果出现了IF以外的情况,不就成死循环了么
N_chow 2001-12-15
  • 打赏
  • 举报
回复
如果Cursor里的第一筆記錄的ExeT不等於0的話,那麼肯定是死循环。
因為Continue只是返回到WHILE (@@Fetch_status=0)處執行,而@Exet又不等於0,所以又不會去執行Fetch Next這一條取下一個@ExET的值,所以肯定是死循环.
nashan 2001-12-15
  • 打赏
  • 举报
回复
这回明白了吧!
net_steven 2001-12-15
  • 打赏
  • 举报
回复
笨!楼上解释了这么多还没整明白,今天心情好,替你找了帮助,是SQL,不过ORACLE也一样:
--------------------------------------------------------
WHILE
设置重复执行 SQL 语句或语句块的条件。只要指定的条件为真,就重复执行语句。可以使用 BREAK 和 CONTINUE 关键字在循环内部控制 WHILE 循环中语句的执行。

语法
WHILE Boolean_expression
{ sql_statement | statement_block }
[ BREAK ]
{ sql_statement | statement_block }
[ CONTINUE ]

参数
Boolean_expression

返回 TRUE 或 FALSE 的表达式。如果布尔表达式中含有 SELECT 语句,必须用圆括号将 SELECT 语句括起来。

{sql_statement | statement_block}

Transact-SQL 语句或用语句块定义的语句分组。若要定义语句块,请使用控制流关键字 BEGIN 和 END。

BREAK

导致从最内层的 WHILE 循环中退出。将执行出现在 END 关键字后面的任何语句,END 关键字为循环结束标记。

CONTINUE

使 WHILE 循环重新开始执行,忽略 CONTINUE 关键字后的任何语句。

bluepower2008 2001-12-15
  • 打赏
  • 举报
回复
1 DECLARE PMCJOBD_CURSOR CURSOR FOR
2 SELECT NAME,EXET FROM EMPL
3 END

4 OPEN PMCJOBD_CURSOR
5 FETCH NEXT FROM PMCJOBD_CURSOR INTO @NAME,@EXEC
6 WHILE (@@FETCH_STATUS = 0)
7 BEGIN--游标开始

8 IF @EXET = 0
9 BEGIN
10 FETCH NEXT FROM PMCJOBD_CURSOR INTO @NAME,@EXET
11 CONTINUE
12 END

为了解释方便,在语句前面加上了行号。
第一个错误:第5句话的变量@EXEC应该为@EXET吧?
第二个错误:第12句的END是匹配前面的第7句的BEGIN还是第9句的BEGIN,无论那个,都少了一个END。
第三个错误:当变量@EXET的值不等于0时,就不执行Fetch Next了,然后继续判断当前的记录的@EXET,所以老是导致死循环。

据我分析,在12句后应该还有代码,你是不是没有写出来。

12 END
13 --执行某些sql语句
.....
14 FETCH NEXT FROM PMCJOBD_CURSOR INTO @NAME,@EXET
15 END

COUTINUE的意思就是当@EXET=0时,不执行13句的sql语句,直接跳到下一条记录。
如果这样说你还不明白,就去看看C语言编程吧!
trouble 2001-12-15
  • 打赏
  • 举报
回复

还是不明白 SORRY ! 麻烦再说说。 我加50分
内容概要:本文围绕“阶梯碳下考虑P2G-CCS与供需灵活响应的IES优化调度”展开,基于Matlab平台构建综合能源系统(IES)在阶梯式碳交易机制下的优化调度模型。研究深度融合电制气(P2G)与碳捕集、利用与封存(CCS)技术,结合需求侧灵活响应机制,旨在提升系统的低碳运行能力与经济性。通过建立多能流耦合的优化模型,协调电力、天然气、热力等多种能源形式的协同调度,有效降低系统碳排放强度,并借助YALIMIP工具包调用求解器进行高效求解。文档提供了完整的代码实现、模型构建流程与结果分析方法,涵盖从问题建模到仿真实现的全过程,具备较强的可复现性与科研参考价值。; 适合人群:具备电力系统、能源系统或优化建模相关背景的研究生、高校教师及工程技术人员,尤其适合从事综合能源系统、碳减排策略、P2G与CCS技术集成研究的专业人员,需熟练掌握Matlab编程与基本的数学规划知识。; 使用场景及目标:①用于研究阶梯式碳交易政策下综合能源系统的低碳经济调度策略;②支撑P2G-CCS技术与需求响应机制在IES中的仿真集成与性能评估;③作为撰写高水平学术论文(如EI/SCI收录)的技术基础与复现资源,推动碳中和背景下能源系统优化方向的创新研究。; 阅读建议:建议结合百度网盘提供的完整代码与资料包,按照模块逐步调试程序,重点理解目标函数的设计逻辑、碳交易成本的建模方式、约束条件的数学表达及求解器的配置方法,同时关注多能耦合设备的建模细节,配合公众号“荔枝科研社”获取持续的技术支持与案例拓展。
内容概要:本文系统研究了基于卷积神经网络(CNN)与支持向量机(SVM)融合的CNN-SVM混合模型在数据分类预测中的应用,尤其聚焦于工业故障识别领域。通过Matlab平台实现,该方法首先利用CNN强大的多层次特征提取能力对原始输入数据进行深度特征学习,自动捕获关键局部模式与空间结构信息,随后将提取的高层特征作为输入传递至SVM分类器,借助SVM在高维空间中小样本条件下卓越的分类性能与泛化能力完成最终判别任务。文中详尽阐述了模型的整体架构设计、网络参数配置、训练优化流程及特征迁移机制,充分结合了深度学习在特征表达上的优势与传统机器学习在分类决策上的稳健性。实验部分通过实际故障数据集验证了该混合模型相较于单一CNN或SVM模型在分类准确率、鲁棒性和抗过拟合能力方面的显著提升,证明了其在复杂故障诊断任务中的有效性与先进性; 适合人群:具备一定机器学习与深度学习理论基础,熟悉Matlab编程环境,从事故障诊断、模式识别、智能制造、电力系统监控或工业数据分析等相关领域的研究生、科研人员及工程技术开发者; 使用场景及目标:① 应用于旋转机械、电力设备、航空航天等领域的多类别故障识别与状态监测;② 掌握深度特征提取与传统分类器融合的技术路径,提升小样本、高噪声环境下数据分类的精度与可靠性;③ 为撰写高水平学术论文、开展科研项目或工程实践提供可复现的算法框架与完整代码支持; 阅读建议:读者应深入理解CNN与SVM的协同工作机制,重点分析特征提取层与分类层之间的接口设计,建议动手运行并调试所提供的Matlab代码,尝试在不同数据集上进行迁移实验与参数调优,以全面掌握该混合模型的应用技巧与优化策略。

34,876

社区成员

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

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