mysql部分回滚_mysql 事务之使用savepoint部分回滚

十年磨一剑

我们可以使用mysql中的savepoint保存点来实现事务的部分回滚~

基本用法如下

SAVEPOINT identifier

ROLLBACK [WORK] TO [SAVEPOINT] identifier

RELEASE SAVEPOINT identifier

1、使用 SAVEPOINT identifier 来创建一个名为identifier的回滚点

2、ROLLBACK TO identifier,回滚到指定名称的SAVEPOINT,这里是identifier

3、 使用 RELEASE SAVEPOINT identifier 来释放删除保存点identifier

4、如果当前事务具有相同名称的保存点,则将删除旧的保存点并设置一个新的保存点。

5、回滚到SAVEPOINT语句返回以下错误,则表示不存在具有指定名称的保存点:

ERROR 1305 (42000): SAVEPOINT identifier does not exist

6、如果执行START TRANSACTION,COMMIT和ROLLBACK语句,则将删除当前事务的所有保存点。

在mysql客户端实验一下

准备数据

SET NAMES utf8mb4;

SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------

-- Table structure for mylock

-- ----------------------------

DROP TABLE IF EXISTS `mylock`;

CREATE TABLE `mylock` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL,

PRIMARY KEY (`id`) USING BTREE

) ENGINE = InnoDB AUTO_INCREMENT = 7 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci ROW_FORMAT = Dynamic;

-- ----------------------------

-- Records of mylock

-- ----------------------------

INSERT INTO `mylock` VALUES (1, 'a');

INSERT INTO `mylock` VALUES (2, 'b');

INSERT INTO `mylock` VALUES (3, 'c');

INSERT INTO `mylock` VALUES (4, 'd');

SET FOREIGN_KEY_CHECKS = 1;

进入mysql客户端操作下

创建一个保存点,并回滚至之。看看数据情况

mysql> set @@autocommit = 0;

Query OK, 0 rows affected (0.00 sec)

mysql> select * from mylock;

+----+------+

| id | name |

+----+------+

| 1 | a |

| 2 | b |

| 3 | c |

| 4 | d |

+----+------+

4 rows in set (0.02 sec)

mysql> INSERT INTO test.mylock(id, name) VALUES (5, 'e');

Query OK, 1 row affected (0.00 sec)

mysql> savepoint point_1; 创建保存点

Query OK, 0 rows affected (0.00 sec)

mysql> INSERT INTO test.mylock(id, name) VALUES(6, 'f');

Query OK, 1 row affected (0.00 sec)

mysql> select * from mylock;

+----+------+

| id | name |

+----+------+

| 1 | a |

| 2 | b |

| 3 | c |

| 4 | d |

| 5 | e |

| 6 | f |

+----+------+

6 rows in set (0.03 sec)

mysql> rollback to point_1;回滚到指定保存点

Query OK, 0 rows affected (0.00 sec)

mysql> select * from mylock;再次查询id=6的记录消失掉了

+----+------+

| id | name |

+----+------+

| 1 | a |

| 2 | b |

| 3 | c |

| 4 | d |

| 5 | e |

+----+------+

5 rows in set (0.05 sec)

一个保存点不删除则可以存在一个事务中被多次使用

c93c1730e5dc

image.png

删除保存点示例

c93c1730e5dc

image.png

覆盖保存点示例

c93c1730e5dc

image.png

保存点失效示例

保存点因为提交事务和新开事务而失效,保存点只能使用在当前事务中

c93c1730e5dc

image.png

在spring中我们可以使用 @Transactional(propagation=Propagation.NESTED)

注解申明一个嵌套事务来使用保存点功能,达到事务的部分回滚目的

可以看看这篇文章,关于嵌套事务的https://www.jianshu.com/p/c6d4095f5833

在jdbc里可以使用savepoint

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值