SQL中如何进行 ‘’撤销‘’ 操作-详解

ops/2024/10/21 13:40:42/

在 SQL 中,撤销已经执行的操作通常涉及两个主要的概念:事务控制和回滚操作。

### 1. 事务控制
在支持事务的数据库管理系统(如 MySQL 的 InnoDB 引擎)中,您可以使用事务来确保数据的完整性。事务可以确保一系列的操作要么全部成功,要么全部失败。

- **开启事务**:

  START TRANSACTION;

- **提交事务**(使所有更改永久生效):

  COMMIT;

- **回滚事务**(撤销所有未提交的更改):

  ROLLBACK;

### 2. 回滚操作
如果您已经执行了一些更改(例如,通过 `INSERT`、`UPDATE` 或 `DELETE` 语句),并且希望撤销这些更改,您可以使用 `ROLLBACK` 语句。但是,请注意,只有那些在当前事务中的更改可以被回滚。如果您的更改已经通过 `COMMIT` 提交,那么它们将永久生效,无法通过 `ROLLBACK` 撤销。

### 示例
假设您在一个事务中执行了以下操作:

START TRANSACTION;UPDATE accounts SET balance = balance - 100 WHERE account_id = 1;
UPDATE accounts SET balance = balance + 100 WHERE account_id = 2;

如果您在提交事务之前发现第一个更新操作有误,您可以撤销所有未提交的更改:

ROLLBACK;

这将撤销这两个更新操作,因为它们都在同一个事务中。

### 注意事项
- 并非所有的数据库引擎都支持事务。例如,MySQL 的 MyISAM 引擎不支持事务。
- 在默认情况下,许多数据库系统(包括 MySQL)在每个单独的操作后自动提交事务。这意味着,如果您没有明确地开始一个事务,每个 `INSERT`、`UPDATE` 或 `DELETE` 语句都会立即生效并无法撤销。
- 为了能够撤销操作,确保您了解数据库的事务配置,并在必要时正确使用 `START TRANSACTION`、`COMMIT` 和 `ROLLBACK` 语句。

要在 MySQL 中使用 ROLLBACK 来撤销已经执行的语句,您需要先关闭自动提交模式,然后显式地管理事务。以下是详细步骤:

  1. 关闭自动提交模式: 您需要将 autocommit 变量设置为 0,这样就不会在每个语句执行后自动提交事务了。

    //查看事务的提交方式
    SHOW @@AUTOCOMMIT
    //设置事务的提交方式,1为自动提交,0为手动提交,该设置只对当前会话有效
    //默认是为1 即自动提交,所以平常执行的sql语句都是自动提交的
    SET autocommit = 0;
  2. 执行 SQL 语句: 在关闭自动提交模式后,您可以执行多个 SQL 语句,这些语句的更改不会立即生效,而是会保持在当前事务中。

    UPDATE table_name SET column_name = 'new_value' WHERE condition;
    -- 更改尚未提交,可以在此时使用 ROLLBACK 或 COMMIT在当前事务中,你可以查询 table_name 表,并看到更新后的结果。其他事务或会话查询同一 table_name 表时,看不到这些更改,因为更改还没有被提交
  3. 使用 ROLLBACK 撤销更改: 如果您发现需要撤销事务中的更改,可以使用 ROLLBACK 语句。这将撤销当前事务中的所有更改。

    ROLLBACK;
    -- 所有更改被撤销,数据恢复到事务开始前的状态
  4. 使用 COMMIT 提交更改: 如果您确认事务中的更改是正确的,可以使用 COMMIT 语句来提交这些更改,使它们永久生效。

    COMMIT;
    -- 更改被提交,无法再使用 ROLLBACK 撤销
  5. 重新开启自动提交模式(可选): 如果您完成事务管理后,想要恢复自动提交模式,可以再次将 autocommit 变量设置为 1

    SET autocommit = 1;

示例

以下是一个完整的示例,展示如何使用 ROLLBACK 来撤销更改:

-- 关闭自动提交模式
SET autocommit = 0;-- 开始事务
START TRANSACTION;-- 执行更新操作//执行完后只有当前的会话中可以查看执行结果,他是没真正的提交,
UPDATE accounts SET balance = balance - 100 WHERE account_id = 1;
UPDATE accounts SET balance = balance + 100 WHERE account_id = 2;-- 检查操作是否正确,如果需要撤销
ROLLBACK;
-- 所有更改被撤销-- 如果操作正确,可以提交事务//提交了就不能更改了
COMMIT;
-- 更改被提交

通过这种方式,您可以更灵活地管理数据库事务,确保数据的完整性和一致性。


http://www.ppmy.cn/ops/121229.html

相关文章

【JavaEE】http/https 超级详解

🔥个人主页: 中草药 🔥专栏:【Java】登神长阶 史诗般的Java成神之路 🦊一.定义 HTTP(HyperText Transfer Protocol)即超文本传输协议,他是应用非常广泛的应用层协议,是…

GPIO端口的使用

目录 一. 前言 二. APB2外设时钟使能寄存器 三. GPIO端口的描述 四. GPIO端口使用案例 一. 前言 基于库函数的开发方式就是使用ST官方提供的封装好的函数。而如果没有添加库函数,那就是基于寄存器的开发方式,这种方式一般不是很推荐。因为由于ST对寄存…

Vue和axios零基础学习

Vue的配置与项目创建 在这之前要先安装nodejs 安装脚手架 官网 Home | Vue CLI (vuejs.org) 先运行,切换成淘宝镜像源,安装速度更快 npm config set registry http://registry.npm.taobao.org 创建项目 用编译器打开一个空文件,在终端输入…

Stm32的bootloader无法使用问题

Stm32的bootloader无法使用问题 用不了一键下载电路 首先简单地对此处涉及的内容进行介绍:如果stm32的BOOT0引脚为低电平时,系统从FLASH中启动,而如果BOOT0引脚为高电平,且BOOT1为低电平时,系统从自举程序(bootloader)中启动. 我在自制照相机设计中加入了ISP一键下载电路,如…

是否是 2 的幂次方

给你一个整数 n,请你判断该整数是否是 2 的幂次方。如果是,返回 true ;否则,返回 false 。 如果存在一个整数 x 使得 n 2x ,则认为 n 是 2 的幂次方。 示例 1: 输入:n 1 输出:tr…

JS设计模式之观察者模式:观察者与可观察对象的巧妙互动

一. 前言 在前端开发中,我们经常会遇到需要对用户的操作进行响应的场景,例如页面上的按钮点击、输入框内容变化等。为了实现这种响应式的设计,我们可以使用观察者模式来解耦各个组件之间的依赖关系。 本文将详细介绍观察者模式的原理和实现…

AIGC: 10 AI转文服务器的搭建过程记录

上图是台风席卷城市,现在企业的服务基本都是混合部署,云计算厂商的机房往往可以提供比较好的保护,一般在地下,扛多少级地震,扛多少级台风,而自建机房,往往写字楼经常停电,网络运营上…

从零开始讲PCIe(3)——FunctionsDeviceBusSystem

在PCI架构中,Functions(功能)、Device(设备)、Bus(总线)、和System(系统)是层次化的概念,每个层次分别描述了不同的结构和作用。让我们详细看看这些术语的定义…