欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

第一个MySQL 存储过程_MySQL

程序员文章站 2022-05-24 23:29:40
...
bitsCN.com

昨天写了人生第一个mysql存储过程;遗憾的是,这个存储过程最后还是没用上,用php代码替代

话说mysql的存储过程真是反人类,不查reference,基本不能看懂那些语句;语言中能和它相比的,只有bash shell脚本了

好了,记录一下这个存储过程吧:

DELIMITER //CREATE PROCEDURE get_task(IN qstatus int, IN prj varchar(20))BEGIN    DECLARE task_id INT DEFAULT 0;    DECLARE done INT DEFAULT 0;    DECLARE cur CURSOR FOR        SELECT id FROM task WHERE status=qstatus and project=prj limit 1;    DECLARE EXIT HANDLER FOR SQLEXCEPTION    BEGIN                ROLLBACK;    END;    declare exit handler for not found    BEGIN                CLOSE cur;                ROLLBACK;    END;                START TRANSACTION;    OPEN cur;                FETCH cur INTO task_id;    update task set status=2 where id=task_id;    CLOSE cur;    commit;    SELECT * from task where id=task_id;ENDDELIMITER ;

bitsCN.com