繁体   English   中英

没有START TRANSACTION语句的回滚在MySQL存储过程中不起作用

[英]Rollback without START TRANSACTION statement is not working in MySQL Stored Procedure

我正在使用mysql v5.6。

通过存储过程在用户表中插入重复记录后,将引发异常,这很好,但无法回退表POSTS。

这是SP的SQL代码:

 DELIMITER //
 CREATE PROCEDURE usp_add_user_tests
  ( IN `i_name` VARCHAR(50), 
  IN `i_email` VARCHAR(100), 
  IN `i_status` TINYINT(1) UNSIGNED, 
  OUT `p_sqlcode` INT(11) UNSIGNED, 
  OUT `p_status_message` VARCHAR(100) 
 ) 
 MODIFIES SQL DATA 

 BEGIN 
 DECLARE duplicate_key CONDITION FOR 1062; 
 DECLARE EXIT HANDLER FOR duplicate_key 
 BEGIN SET p_sqlcode=1062; SET p_status_message='Duplicate key error';
ROLLBACK ; 
 END; 

 SET p_sqlcode=0; 

 INSERT INTO posts (title) 
 VALUES('test'); 

 INSERT INTO users (name,email,status) 
 VALUES(i_name,i_email,i_status); 

 IF p_sqlcode<>0 THEN 
 SET p_status_message=CONCAT(p_status_message,' when inserting new user'); 
 ELSE
 SET p_status_message='Success'; 
 END IF; 

 END //
DELIMITER ; 

是否可以在不使用Start Transaction语句的情况下回滚表帖子

我认为您实际上并未开始“交易”。 我很确定您需要实现此处列出的一种机制: https : //dev.mysql.com/doc/refman/5.7/en/commit.html

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM