MySQL: cursor

1、在能够使用游标前,必须声明(定义)它。这个过程实际上没有检索数据,他只是使用select 语句。

2、一旦声明后,必须打开游标以供使用。这个过程用前面定义的select 语句把数据实际检索出来

3、对于填有数据游标,根据需要取出(检索)各行。

4、在结束游标使用时,必须关闭游标

在声明游标后,可根据需要频繁地打开和关闭游标。在游标打开后,可根据需要频繁地执行取操作。

 

复制代码
CREATE DEFINER=`root`@`localhost` PROCEDURE `proc_cursor`( IN threshold_profit INT, OUT total_count INT )
BEGIN
    DECLARE accumulative_profit INT DEFAULT 0;  # 累计profit
    DECLARE current_profit INT DEFAULT 0;  # 当前cursor对应的profit
    DECLARE accumulative_count INT DEFAULT 0;  # 累计rows
    # Define CURSOR
    DECLARE CURSOR_PROFIT CURSOR FOR SELECT profit FROM fuze ORDER BY profit DESC;
    # Open CURSOR
    OPEN CURSOR_PROFIT;
    
    REPEAT
        FETCH CURSOR_PROFIT INTO current_profit;# INTO后面变量个数次序必须与CURSOR声明的SELECT列数对应
        
        SET accumulative_profit = accumulative_profit + current_profit;# 累计profit
        
        SET accumulative_count = accumulative_count + 1;# 累计rows
        
        UNTIL accumulative_profit > threshold_profit 
    END REPEAT;
    
    CLOSE CURSOR_PROFIT;
    
    SET total_count = accumulative_count;  # 为输出变量赋值
END
复制代码

 

posted @   ascertain  阅读(174)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
历史上的今天:
2021-04-22 python zipfile
2021-04-22 正则Regular Expression
点击右上角即可分享
微信分享提示