如何停止在 MySQL 中执行完整的存储过程?

Posted

技术标签:

【中文标题】如何停止在 MySQL 中执行完整的存储过程?【英文标题】:How to stop execute full stored procedure in MySQL? 【发布时间】:2018-01-21 11:04:01 【问题描述】:

我在 mysql 中编写了一个程序。我在我的程序中设置了一些条件。 IF 条件不会填满,则程序将退出或完整的程序不会执行。这意味着我想停止执行我的程序的下一行。在 oracle 中,我使用了 GOTO stop_level;。在 MySQL 中,我已经看到我的完整过程已经执行。我想声明一个 LEAVE 标签,以便它可以跳转到 LEAVE 标签并返回设置消息。这是我的 MySQL 程序

CREATE PROCEDURE my_spring.`login_auth`(IN  in_email      varchar(100),
                                    IN  in_password   varchar(100),                                       
                                    OUT user_id       INT,
                                    OUT out_code      INT,
                                    OUT out_message   VARCHAR(1024))
BEGIN
  BEGIN
   IF in_email IS NULL OR in_email = ''
    THEN
       SET out_code = 1;
       SET out_message = 'Please Enter Your Email.';
        /* Exit here*/
  END IF;

 IF in_password IS NULL OR in_password = ''
   THEN
     SET out_code = 1;
     SET out_message = 'Please Enter Your password.';
     /* Exit here*/
 END IF;


 END  ;


END;

我用过oracle的GOTO功能。当条件不匹配时,我调用 GOTO stop_label,它将跳转到停止标签不执行下一行代码。我想像 oracle 一样处理我的程序 GOTO stop_level 这是 stop_level 代码

  <<stop_level>>
 IF out_code = 0
 THEN
    COMMIT;
    out_message := out_message;
  ELSE
     ROLLBACK;
      out_code := 1;
      out_message := out_message;
  END IF;

怎么做?

【问题讨论】:

如果我没记错的话,你的问题是什么类似于 MySQL 中的GOTO。对吗? How to use goto label in MySQL stored function的可能重复 你是对的。我想要这样处理.. 【参考方案1】:

MySQL 没有类似于 Oracle 的 GOTO,但他们确实可以选择使用 LEAVE 级别(您已经提到过)移动控制。在您的场景中,您可以调整 BEGIN

leaveBlock:BEGIN
IF in_email IS NULL OR in_email = ''
    THEN
       SET out_code = 1;
       SET out_message = 'Please Enter Your Email.';
        LEAVE leaveBlock;
  END IF;

 IF in_password IS NULL OR in_password = ''
   THEN
     SET out_code = 1;
     SET out_message = 'Please Enter Your password.';
     LEAVE leaveBlock;
 END IF;

END leaveBlock;

【讨论】:

以上是关于如何停止在 MySQL 中执行完整的存储过程?的主要内容,如果未能解决你的问题,请参考以下文章

在SQLSERVER里面,如何写一个存储过程来创建跟踪?

MySql 存储过程实例(附完整注释)

navicat for MySQL中的 查询编辑器中如何执行存储过程?

MYSQL存储过程中事务和DECLARE EXIT/CONTINUE HANDLER的使用

如何执行存储在 MySQL 中的将 ID 从一个表插入到另一个表的过程?

如果发生多行,如何在 php mysql 的侧存储过程中执行选择查询?