首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL事务部分回滚-回滚到指定保存「建议收藏」

我们可以在mysql事务处理过程中定义保存(SAVEPOINT),然后回滚到指定的保存前的状态。 定义保存,以及回滚到指定保存前状态的语法如下。...定义保存—SAVEPOINT 保存点名; 回滚到指定保存—ROLLBACK TO SAVEPOINT 保存点名: 下面演示将向表user中连续插入3条数据,在插入第2条数据的后面定义一个保存,最后看看能否回滚到此保存...事务开始 mysql> BEGIN; Query OK, 0 rows affected (0.00 sec) 3、向表user中插入2条数据 mysql> INSERT INTO user VALUES...test以后插入的记录没有显示了,即成功团滚到了定义保存test前的状态。...利用保存可以实现只提交事务中部分处理的功能。

2K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL事务知识盘点

    本篇内容包括:MySQL 事务概念、MySQL 事务隔离级别以及MySQL 事务隔离的实现 一、MySQL 事务概念 一般来说, MySQL 事务都是指在 InnoDB 引擎下,MyISAM 引擎是不支持事务的...3、MySQL 中执行事务 事务的执行过程如下,以 begin 或者 start transaction 开始,然后执行一系列操作,最后要执行 commit 操作,事务才算结束。...读提交事务隔离级别是大多数流行数据库的默认事务隔离界别,比如 Oracle,但是不是 MySQL 的默认隔离界别。...要说明的是,当你在 MySQL 中测试幻读的时候,并不会出现上图的结果,幻读并没有发生,MySQL 的可重复读隔离级别其实解决了幻读问题 6、串行化 串行化是4种事务隔离级别中隔离效果最好的,解决了脏读...MySQL 会为这张表中所有行加行锁,没错,是所有行。但是呢,在加上行锁后,MySQL 会进行一遍过滤,发现不满足的行就释放锁,最终只留下符合条件的行。

    32220

    MySql 三大知识——索引、锁、事务

    注意:小表使用全表扫描更快,中大表才使用索引。超级大表索引基本无效。...如下图所示: 我们看到,B+ Tree 将所有的 data 数据都保存到了叶子节点中,非也子节点只保存索引和指针。...事务 事务是数据库永恒不变的话题, ACID:原子性,一致性,隔离性,持久性。 四个特性,最重要的就是一致性。而一致性由原子性,隔离性,持久性来保证。 原子性由 Undo log 保证。...一张经典的图: 这里有个注意,关于幻读,在数据库规范里,RR 级别会导致幻读,但是,由于 Mysql 的优化,MySql 的 RR 级别不会导致幻读:在使用默认的 select 时,MySql 使用...原理剖析: RU 发生脏读的原因:RU 原理是对每个更新语句的行记录进行加锁,而不是对整个事务进行加锁,所以会发生脏读。而 RC 和 RR 会对整个事务加锁。

    71820

    MySql 三大知识——索引、锁、事务

    注意:小表使用全表扫描更快,中大表才使用索引。超级大表索引基本无效。...我们看到,B+ Tree 将所有的 data 数据都保存到了叶子节点中,非也子节点只保存索引和指针。 我们假设一个非页子节点是 16kb,每个索引,即主键是 bigint,即 8b,指针为 8b。...事务 事务是数据库永恒不变的话题, ACID:原子性,一致性,隔离性,持久性。 四个特性,最重要的就是一致性。而一致性由原子性,隔离性,持久性来保证。 原子性由 Undo log 保证。...这里有个注意,关于幻读,在数据库规范里,RR 级别会导致幻读,但是,由于 Mysql 的优化,MySql 的 RR 级别不会导致幻读:在使用默认的 select 时,MySql 使用 MVCC 机制保证不会幻读...原理剖析: RU 发生脏读的原因:RU 原理是对每个更新语句的行记录进行加锁,而不是对整个事务进行加锁,所以会发生脏读。而 RC 和 RR 会对整个事务加锁。

    88240

    MySQL 事务

    MySQL中,事务具有以下四个特性,通常称为ACID特性: 1.原子性(Atomicity):事务中的所有操作要么全部执行成功,要么全部失败。...在MySQL中,可以使用以下命令来控制事务: •START TRANSACTION; or BEGIN;:开始一个新的事务。•COMMIT;:提交当前事务,使事务中的所有修改生效。...事务并发 事务并发是指多个事务同时执行,这可能会导致以下问题: 1.丢失更新:当两个或多个事务同时对相同的数据进行更新时,最后提交的事务可能会覆盖之前提交的事务所做的修改,导致之前的更新丢失。...MySQL支持以下四种事务隔离级别: 1.未提交读(Read Uncommitted):允许一个事务读取另一个事务未提交的数据。这可能导致脏读、不可重复读、幻读。...查看、设置MySQL事务隔离级别 -- 查看事务隔离级别 -- 使用系统变量查询 SELECT @@transaction_isolation; -- 5.7.20之前 SHOW VARIABLES

    9810

    mysql 事务

    1)查看哪些引擎支持事务: SQL: Show engines; 2)查看表引擎类型: Show create table table_name; 3)查看是否自动提交: show variables...like ‘%autocommit%’; 4)事务开始的方法: a) mysql_autocommit(0); 如果程序在此处coredump,请检查是否connect db b) SQL:Set autocommit...=0; c) Begin work; d) Start transaction; 5)事务结束的方法: a) SQL:Commit/rollback b) Mysql_commit/mysqlrollback...c) 隐式事务,参考http://blog.csdn.net/blues1021/article/details/6329190 并发事务: 锁机制: 乐观锁:通过where条件控制、通过version...字段或自定义字段的值控制; update影响的行数:mysql_affected_rows的返回值,可根据它决定事务是否终止 悲观锁=排他锁 Select  * from table for update

    2.4K10

    MySQL事务

    几个并行执行的事务,其执行结果必须与按某一顺序串行执行的结果相一致 隔离性(Isolation):事务的执行不受其他事务的干扰,事务执行的中间结果对其他事务必须是透明的 持久性(Durability):...对于任意已提交事务,系统必须保证该事务对数据库的改变不被丢失,即使数据库出现故障 提交 默认隔离级别可重复读,若事务级别为读已提交,则终端二不commit的情况下可以读取到终端一的数据。...### 终端一 begin; 开启 insert into students (sname) value ("sss"); commit; 只有commit才表示执行成功 ### 终端二 mysql>...insert into students (sname) value ("kksk"); 测试语句 ### 终端二 mysql> select * from students; +----+-----...-+ | id | sname | +----+-------+ | 1 | Gage | | 2 | sss | | 4 | kksk | +----+-------+ 查看隔离级别 mysql

    2.2K40

    Mysql事务

    事务是一组被视为单个逻辑单元的操作,这些操作要么全部执行成功,要么全部回滚。在数据库中,事务是确保数据完整性和一致性的重要机制。以下是关于事务的一些基本概念和用法。 事务是什么?...持久性(Durability):事务执行后,对数据库的修改应该是永久性的。 事务的语法 Mysql 中使用 START TRANSACTION 和 COMMIT 或 ROLLBACK 语句来控制事务。...事务有三种状态: 活动状态:这是事务的起始状态,表示事务正在执行中。...在此状态下,事务已经执行完毕,但是还没有被提交。在这个状态下,数据库引擎将会等待用户提交事务或者回滚事务的操作。...Mysql 支持四种隔离级别: 读未提交(READ UNCOMMITTED):这个隔离级别最宽松,允许事务读取其他事务未提交的数据。

    15210

    MySQL·事务

    MySQL 默认采用自动提交模式,对于单条 SQL 语句,数据库系统自动将其作为一个事务执行,这种事务被称为隐式事务。...COMMIT 是指提交事务,即试图把事务内的所有 SQL 所做的修改永久保存。如果 COMMIT 语句执行失败了,整个事务也会失败。...分别开启两个 MySQL 客户端连接,按顺序依次执行事务 A 和事务 B: 时刻 事务 A 事务 B 1 SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED...分别开启两个 MySQL 客户端连接,按顺序依次执行事务 A 和事务 B: 时刻 事务 A 事务 B 1 SET TRANSACTION ISOLATION LEVEL READ COMMITTED;...分别开启两个 MySQL 客户端连接,按顺序依次执行事务 A 和事务 B: 时刻 事务 A 事务 B 1 SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;

    1.8K10

    MySQL事务

    我们开启另一个终端同时也启动一个事务: 首先我们当前的表是空的,我们以左边的终端为主,我们先创建一个保存 s1,对应的语句为 savepoint s1;;然后我们往表里插入一个数据;接着再创建一个保存...s2,然后再插入一个数据,如下图: 然后我们在另一个终端查看该表,是可以看见另一个终端插入的数据的: 上面所有的创建保存、插入数据的操作都是一个事务,那么我们操作失误了,想要撤回 Mike 的数据,...我们就可以定向地回滚,可以回滚到指定的位置,例如我们想撤回 Mike 的数据,我们回滚到 s2 的保存即可,对应的语句为:rollback to s2;,此时我们再从另一个终端查看该表时,就会发现 Mike...事务操作注意事项 如果没有设置保存,也可以回滚,只能回滚到事务的开始。...直接使用 rollback (前提是事务还没有提交); 如果一个事务被提交了(commit),则不可以回退(rollback); 可以选择回退到哪个保存; InnoDB 支持事务, MyISAM 不支持事务

    10610

    Mysql事务

    事务 简单来说,事务就是操作一系列事件,要么全部完成,要么全部不完成。...特性(ACID) 原子性:一系列事件,要么全部完成,要么全部不完成 一致性:在事务开始之前和事务结束以后,数据库的完整性没有被破坏 持久性:事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失...账号2 人民币50元 public static void main(String[] args) throws SQLException { String url = "jdbc:mysql...,不可重复读,虚读 Serializable隔离级别下的事务具有最高的安全性,但是,由于事务是串行执行,所以效率会大大下降 建议细看:事务隔离级别的图文 脏读:一个事务读取到另外一个事务未提交的数据...丢失修改:两个事务同时访问数据,第一个修改数据后,第二个也修改数据,导致第一个修改数据丢失 不可重复读:第一个事务读取到数据后,另外一个事务修改数据并提交后第一个事务再次读取,第一个事务两次读取的数据不一样

    1.6K20

    MySQL——事务

    事务概述 事务是数据库系统区别于其他一切文件系统的重要特性之一 事务是一组具有原子性的SQL语句,或是一个独立的工作单元 事务特点 1....原子性 一个事务必须被视为不可分离的最小工作单位,整个事务中的所有操作要么全部提交成功,要么全部失败,对于一个事务来说,不可能只执行其中的一部分操作。...一致性(CONSISTENCY) 一致性是指事务将数据库从一种一致性状态转换到另外一种一致性状态,在事务开始之前和事务结束后数据库中数据的完整性没有被破坏。...,则其所做的修改就会永远保存到数据库中,此时即使系统崩溃,已经提交的修改数据也不会丢失。...大事务 运行的时间比较长,操作的数据比较多的事务 风险: 锁定太多的数据,造成大量的阻塞和锁超时 回滚所需要的时间比较长 执行时间长,容易造成主从延迟 如何处理大事务

    1.7K20

    MySQL 事务

    小伙手撕MySQL事务,发生了什么? 事务的4大特性 A (Atomicity) 原子性:事务的操作序列不可再拆分:这也是都成功都失败的意思。...事务只能读取其他事务提交之后的数据,我们来模拟以下这个过程会出现的问题: 小伙手撕MySQL事务,发生了什么?...我们把这两个事务ID理解为版本号。 从插入数据开始,我们来看一下MySQL如何用这两个版本号来隔离事务。 小伙手撕MySQL事务,发生了什么? 此时又有一个事务进来,增加了一条数据并提交结束。...小伙手撕MySQL事务,发生了什么? MVCC 的查找规则1:只能查找创建时间小于等于当前事务 ID 的数据 小伙手撕MySQL事务,发生了什么?...事务5,尝试修改数据 小伙手撕MySQL事务,发生了什么? 此时回到事务2再次查询数据 小伙手撕MySQL事务,发生了什么?

    1.7K40

    MySQL 事务

    事务事务开始(begin transaction)和事务结束(end transaction)之间执行的全体操作组成。在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。... ♞ 持久性:即事务完成后,对数据库数据的修改被持久化存储 1.2 事务控制   在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT 操作。...ROLLBACK 或 ROLLBACK WORK 回滚会结束用户的事务,并撤销正在进行的所有未提交的修改; SAVEPOINT identifier,SAVEPOINT 允许在事务中创建一个保存,一个事务中可以有多个...SAVEPOINT; RELEASE SAVEPOINT identifier 删除一个事务保存,当没有指定的保存时,执行该语句会抛出一个异常; ROLLBACK TO identifier...把事务回滚到标记; SET TRANSACTION 用来设置事务的隔离级别。

    2.1K31
    领券