【重学 MySQL】四十八、DCL 中的 commit 和 rollback

【重学 MySQL】四十八、DCL 中的 commit 和 rollback

  • commit的定义与作用
  • rollback的定义与作用
  • 使用场景
  • 相关示例
  • 注意事项
  • DDL 和 DML 的说明

在这里插入图片描述
在MySQL中,DCL(Data Control Language,数据控制语言)用于管理数据库用户和控制数据的访问权限。而commit和rollback并不是DCL的专属命令,但它们在与事务处理相关的上下文中非常重要。

commit的定义与作用

定义
commit是SQL中的一个事务控制命令,用于提交事务处理,即将自事务开始以来所做的所有更改永久保存到数据库中。

作用

  • 永久保存数据更改:一旦执行commit,事务中的所有更改都将被写入数据库,并且这些更改在之后无法被回滚。
  • 结束当前事务:commit操作标志着当前事务的结束,之后的所有操作都将被视为新的事务。

rollback的定义与作用

定义
rollback也是SQL中的一个事务控制命令,用于回滚事务处理,即撤销事务中的所有更改,并将数据库状态恢复到事务开始之前的状态。

作用

  • 撤销数据更改:rollback可以撤销自事务开始以来所做的所有更改,包括插入、更新和删除操作。
  • 保持数据一致性:在事务处理过程中,如果发生错误或需要取消某些操作,rollback可以确保数据库状态的一致性。

使用场景

  • commit的使用场景

    • 当事务中的所有操作都成功完成,并且需要将这些更改永久保存到数据库时,使用commit。
    • 在进行批量数据插入、更新或删除操作时,为了确保数据的一致性和完整性,可以在操作完成后使用commit。
  • rollback的使用场景

    • 当事务中的某个操作失败,或者由于某种原因需要取消整个事务时,使用rollback。
    • 在进行复杂的事务处理时,如果某个步骤出错,可以使用rollback将数据库状态恢复到事务开始之前的状态,以便重新尝试事务或进行其他处理。

相关示例

以下是一个简单的MySQL事务处理示例,展示了commit和rollback的使用:

-- 开始事务
START TRANSACTION;-- 执行一些SQL操作
INSERT INTO employees (name, position) VALUES ('Alice', 'Engineer');
UPDATE employees SET position = 'Manager' WHERE name = 'Bob';-- 检查操作是否成功
-- 假设这里有一个条件判断,如果某个操作失败,则回滚事务
-- 例如:IF some_error_condition THEN ROLLBACK; END IF;
-- 在实际的SQL脚本中,这通常通过编程语言(如Python、Java等)的逻辑控制来实现-- 如果所有操作都成功,则提交事务
COMMIT;-- 如果发生错误,则回滚事务(这里的回滚操作是假设性的,实际使用时需要在错误处理逻辑中执行)
-- ROLLBACK;

在上面的示例中,如果INSERTUPDATE操作都成功完成,并且没有发生任何错误,那么执行COMMIT会将这些更改永久保存到数据库中。如果某个操作失败或需要取消事务,则可以在错误处理逻辑中执行ROLLBACK,以撤销所有已执行的更改。

注意事项

  • 在使用事务处理时,请确保所有相关的数据库操作都在同一个事务块内执行,以便能够正确地使用commit和rollback来控制事务的提交和回滚。
  • 在执行commit或rollback之前,请确保已经正确地处理了所有可能的错误和异常情况,以避免数据的不一致性和丢失。
  • 对于涉及多个表或复杂业务逻辑的事务处理,建议在进行commit之前进行充分的测试和验证,以确保事务的正确性和可靠性。

综上所述,commit和rollback是MySQL中非常重要的事务控制命令,它们能够确保数据的一致性和完整性,并在事务处理过程中提供灵活的错误处理机制。

DDL 和 DML 的说明

  • DDL 的操作一旦执行,就不可回滚,指令 set autocommit = FALSE 对 DDL 失效
  • DML 的操作默认情况,一旦执行,也是不可回滚的。但是,如果在执行 DML 之前,执行了 set autocommit = FALSE,则执行的 DML 操作就可以实现回滚

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/55698.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

螺蛳壳里做道场:老破机搭建的私人数据中心---Centos下docker学习02(yum源切换及docker安装配置)

2 前期工作 2.1 切换yum源并更新 删除/etc/yum.repos.d/原有repo文件,将Centos-7.repo库文件拷贝到该目录下。 然后清楚原有缓存yum clean all 生成新的缓存yum makecache 更新yum update –y 然后再确认/etc/yum.repos.d/不会有其他库文件,只留下…

elasticsearch设置账号和密码

1、es安装,挂载路径根据实际情况修改 docker run -d --restart always \ --name es \ -e "ES_JAVA_OPTS-Xms512m -Xmx512m" \ -e "discovery.typesingle-node" \ -e "TZAsia/Shanghai" \ -v /mnt/data/efk/es/data:/usr/share/elast…

Android高级控件

文章目录 1.下拉列表Spinner1.数组适配器ArrayAdapter2.简单适配器SimpleAdapter3.基本适配器BaseAdapter 2.列表视图ListView3.网格视图GridView4.翻页视图ViewPager5.翻页标签栏pagerTabStrip6.ViewPager实现引导页7.碎片Fragment1.Fragment静态注册2.Fragment生命周期3.Frag…

Hack Uboot

在硬件评估过程中,经常会遇到采用U-Boot的设备。本文旨在阐述U-Boot是什么,从攻击角度来看它为何如此吸引人,以及这种流行的引导程序所关联的攻击面。 U-Boot 特性 U-Boot,即通用引导加载程序(Universal Boot Loader…

java中创建不可变集合

一.应用场景 二.创建不可变集合的书写格式(List,Set,Map) List集合 package com.njau.d9_immutable;import java.util.Iterator; import java.util.List;/*** 创建不可变集合:List.of()方法* "张三","李四","王五…

问题解决实录 | bash 中 tmux 颜色显示不全

点我进入博客 如下图,tmux 中颜色显示不全: echo $TERM输出的是 screen 但在 bash 里面输出的是 xterm-256 color 在 bash 里面输入: touch ~/.tmux.conf vim ~/.tmux.conf set -g default-terminal "xterm-256color"使之生效 source …

【设计模式-中介者模式】

定义 中介者模式(Mediator Pattern)是一种行为设计模式,通过引入一个中介者对象,来降低多个对象之间的直接交互,从而减少它们之间的耦合度。中介者充当不同对象之间的协调者,使得对象之间的通信变得简单且…

基于ucontext库实现协程类

文章目录 前言协程基础知识协程上下文对称协程与⾮对称协程有栈协程与⽆栈协程 ucontext库接口熟悉一个简单的函数切换自动调用 协程类的实现接口全局变量线程局部变量malloc封装协程切换构造函数协程执行的方法 测试协程切换手动切换复用 前言 协程(Coroutine&…

【从0开始搭建微服务并进行部署】SpringBoot+dubbo+zookeeper

文章目录 说明环境搭建创建项目父模块设置子模块 dubbo-api子模块 dubbo-provider子模块 dubbo-consumer测试项目 docker部署项目完整项目地址 说明 jdk1.8SpringBoot2.x低版本dubbo:请查看之前教程【微服务】SpringBootDubboZooKeeper 实战 关于本教程将采用jdk1…

HTML流光爱心

文章目录 序号目录1HTML满屏跳动的爱心(可写字)2HTML五彩缤纷的爱心3HTML满屏漂浮爱心4HTML情人节快乐5HTML蓝色爱心射线6HTML跳动的爱心(简易版)7HTML粒子爱心8HTML蓝色动态爱心9HTML跳动的爱心(双心版)1…

如何用AI绘画工具生成中国风插画?Midjourney保持风格一致出图

​ 如何运用AI绘画工具如Midjourney,生成符合我们特定要求的艺术作品是一门精进的技巧,尤其当你想生成具有鲜明特色的国风插画时,纯文本提示词的局限性常常使我们难以达到预期效果。然而,借助Midjourney的高级参数功能——特别是s…

【课程学习】随机过程之泊松过程

随机过程之泊松过程 泊松分布泊松过程 泊松分布 二项分布是离散性的分布,泊松分布是把二项分布取n趋于无穷得到的连续分布。也就是在一段时间内不停的观察某件事情发生的次数。 如:一个小时内观察一段路上经过行人的数目,如果每个半个小时观…

Prompt 模版解析:诗人角色的创意引导与实践

Prompt 模版解析:诗人角色的创意引导与实践 Prompt 模版作为一种结构化工具,旨在为特定角色——本例中的“诗人”——提供明确的指导和框架。这一模版详尽地描绘了诗人的职责、擅长的诗歌形式以及创作规则,使其能在自动化系统中更加精确地执…

【Unity】双摄像机叠加渲染

一、前言 之前我在做我的一个Unity项目的时候,需要绘制场景网格的功能,于是就用到了UnityEngine.GL这个图形库来绘制,然后我发现绘制的网格线是渲染在UI之后的,也就是说绘制出来的图形会遮盖在UI上面,也就导致一旦这些…

计算机网络:物理层 —— 物理层下的传输媒体

文章目录 传输媒体导向性媒体同轴电缆双绞线光纤光纤分类中心波长光纤规格光纤的优缺点 非导向性媒体ISM 频段无线电波微波激光红外线可见光 传输媒体 传输媒体是计算机网络设备之间的物理通路,也称为传输介质或传输媒介,并不包含在计算机网络体系结构中…

什么是 ARP 欺骗和缓存中毒攻击?

如果您熟悉蒙面歌王,您就会明白蒙面歌王的概念:有人伪装成别人。然后,当面具掉下来时,您会大吃一惊,知道了这位名人是谁。类似的事情也发生在 ARP 欺骗攻击中,只是令人惊讶的是,威胁行为者利用他…

ModuleNotFoundError: No module named ‘package‘

报错: Traceback (most recent call last): File “”, line 198, in run_module_as_main File “”, line 88, in run_code File "D:\python\helloworld.venv\Scripts\pip.exe_main.py", line 4, in File "D:\python\helloworld.venv\Lib\site-pac…

android 全面屏最底部栏沉浸式

Activity的onCreate方法中添加 this.getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION); Android 系统 Bar 沉浸式完美兼容方案自 Android 5.0 版本,Android 带来了沉浸式系统 ba - 掘金 (juejin.cn)https://juejin.cn/post/7075578…

AI类课程的笔记

信息论、导论、模式识别(数据挖掘)、语义网络与知识图谱、深度学习、强化学习 (零)信息论 详见另一篇博文 信息论自总结笔记(仍然在更新)_信息论也更新了-CSDN博客https://blog.csdn.net/sinat_27382047/article/details/12690…

Python+Django微信小程序前后端人脸识别登录注册

程序示例精选 PythonDjango微信小程序前后端人脸识别登录注册 如需安装运行环境或远程调试,见文章底部个人QQ名片,由专业技术人员远程协助! 前言 这篇博客针对《PythonDjango微信小程序前后端人脸识别登录注册》编写代码,代码整…