视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
mysql存储过程中的事务管理示例及说明_MySQL
2020-11-09 18:25:16 责编:小采
文档


bitsCN.com

mysql存储过程中的事务管理示例及说明

今天研究了下在mysql的存储过程中使用事务的东西,现在写了一个小示例,在此记录一下,便于以后借鉴:

Sql代码

delimiter $$

use test$$

create procedure t_insert_table()

begin

/** 标记是否出错 */

declare t_error int default 0;

/** 如果出现sql异常,则将t_error设置为1后继续执行后面的操作 */

declare continue handler for sqlexception set t_error=1; -- 出错处理

/** 显式的开启事务,它开启后,事务会暂时停止自动提交*/

-- start transaction;

/** 关闭事务的自动提交 */

set autocommit = 0;

insert into t_bom_test(parent_id,child_id) values('D','abc');

insert into t_trigger_test(name,age) values('zhangsan',null);

/** 标记被改变,表示事务应该回滚 */

if t_error=1 then

rollback; -- 事务回滚

else

commit; -- 事务提交

end if;

-- rollback;

-- commit;

end$$

delimiter ;

写完这个后,又发现书本上有很多地方都是直接在开始set autocommit = 0;在最后commit或rollback就完成了,我自己试验了一下,结果出现如下问题:

1)当直接在开始set autocommit = 0;在最后commit或rollback后会出现一下错误:

Error Code: 1048. Column 'age' cannot be null ,然后查看了一下数据库表,发现第一条insert语句执行成功并成功commit了,而第二条则没有;

2)当

Sql代码

/** 标记是否出错 */

declare t_error int default 0;

/** 如果出现sql异常,则将t_error设置为1后继续执行后面的操作 */

declare continue handler for sqlexception set t_error=1; -- 出错处理

这两句代码存在,而结束时不做if-else判断,直接执行rollback语句时,发现即使两条insert语句都执行成功了,但到最后仍然会被回滚掉;当直接执行commit语句时,发现如果第一条insert语句执行成功,第二条insert语句执行失败时,查看数据库表,会发现事务没有回滚。

以上两点是我的一点发现和疑惑,希望在此记录一下,引以为鉴,当然,如果有朋友帮我解决了这个迷惑,我会万分感激的。

bitsCN.com

下载本文
显示全文
专题