mysql事务管理操作详解

作者:随风行云 时间:2024-01-20 10:35:29 

本文实例讲述了mysql事务管理操作。分享给大家供大家参考,具体如下:

本文内容:

  • 什么是事务管理

  • 事务管理操作

  • 回滚点

  • 默认的事务管理

首发日期:2018-04-18


什么是事务管理:

  • 可以把一系列要执行的操作称为事务,而事务管理就是管理这些操作要么完全执行,要么完全不执行(很经典的一个例子是:A要给B转钱,首先A的钱减少了,但是突然的数据库断电了,导致无法给B加钱,然后由于丢失数据,B不承认收到A的钱;在这里事务就是确保加钱和减钱两个都完全执行或完全不执行,如果加钱失败,那么不会发生减钱)。

  • 事务管理的意义:保证数据操作的完整性。

  • mysql中并不是所有的数据引擎都支持事务管理的,只有innodb支持事务管理。

事务管理的特性:

  • 原子性:事务的整个操作是一个整体,不可以分割,要么全部成功,要么全部失败。

  • 一致性:事务操作的前后,数据表中的数据没有变化。

  • 隔离性:事务操作是相互隔离不受影响的。

  • 持久性:数据一旦提交,不可改变,永久的改变数据表数据。


事务管理操作:

  • 开启事务管理:开启之后,下面的sql语句并不会马上执行并把结果写到表中,而是会写到事务日志中。

    • start transaction;

  • 回退操作:回退会清掉开始事务管理之后写到事务日志中的内容,即恢复到开启事务管理之前。

    • 语法:rollback;

    • 注意:回退操作只是回退"写"的内容,对于普通的读表select语句不能回退。

  • 事务提交:将sql语句的结果写到数据表中。

    • 语法:commit:

实验表:


create table bankaccount(id int primary key auto_increment,name varchar(15),money int);
insert into bankaccount(name,money) values("Jobs",2000);
insert into bankaccount(name,money) values("Bill",3000);

mysql事务管理操作详解

mysql事务管理操作详解

补充:

  • 当 commit 或 rollback 语句执行后,事务会自动关闭(将来的更改会隐含提交)。

  • 锁机制:在事务操作一个表时,如果使用索引来取值,那么会锁定到对应行;如果没有使用索引来取值,那么会锁定整个表。锁定之后其他连接无法操作指定行或表。


回滚点:

  • 回滚点可以指定rollback回退的位置【比如现在打了100条命令,发现第81打错了,如果回滚到打了81命令之前一点而不是回滚到开启事务之前就可以节省下很多时间。】

  • 语法:

    • 创建回滚点:savepoint 回滚点名;

    • 回滚到回滚点:rollback to 回滚点名;

mysql事务管理操作详解

补充:

  • 回滚点在事务管理关闭(rollback或commit之后)之后失效,不要在事务之外使用回滚点。


默认的事务管理:

  • 默认情况下,mysql的事务管理是关闭(自动事务)的,语句的结果会马上写到数据表中。

    • 可以通过show variable like 'autocommit';来查看是否开启自动事务,值为1为自动事务已开启,为0则为关闭。

  • 关闭自动事务:set autocommit =0;【关闭后需要commit来执行每一条语句,相当于开始了事务管理】

    • 不过注意的是set autocommit针对的是会话变量,所以这个设置只在此次会话连接中生效。

希望本文所述对大家MySQL数据库计有所帮助。

来源:https://www.cnblogs.com/progor/p/8877821.html

标签:mysql,事务管理
0
投稿

猜你喜欢

  • python datetime时间格式的相互转换问题

    2023-12-22 01:04:29
  • 教你用Python查看茅台股票交易数据的详细代码

    2022-06-05 13:36:16
  • 细说Go语言中空结构体的奇妙用途

    2024-04-23 09:46:09
  • 一篇文章弄懂Python中所有数组数据类型

    2023-01-12 18:25:05
  • 对python requests的content和text方法的区别详解

    2022-10-14 14:28:37
  • Python万字深入内存管理讲解

    2021-06-30 15:49:33
  • Python3实现爬取简书首页文章标题和文章链接的方法【测试可用】

    2021-10-08 00:22:10
  • JavaScript 中级笔记 第四章 闭包

    2024-04-18 10:53:09
  • python中的脚本性能分析

    2023-10-31 00:37:22
  • SQL Server中元数据函数的用法

    2024-01-20 16:26:54
  • 一小时快速入门Python教程

    2023-03-06 04:07:03
  • Python3.5运算符操作实例详解

    2021-06-09 11:41:17
  • 详解如何用Python实现感知器算法

    2023-11-02 13:32:20
  • python爬虫开发之urllib模块详细使用方法与实例全解

    2021-02-24 04:52:42
  • 对acronym、abbr标签的理解

    2008-05-29 13:03:00
  • Python3.7基于hashlib和Crypto实现加签验签功能(实例代码)

    2023-03-25 16:23:00
  • Python全栈之递归函数

    2021-04-05 16:44:54
  • 从XML中读取数据到内存的实例

    2008-09-04 14:43:00
  • 文字解说Golang Goroutine和线程的区别

    2023-10-15 18:56:36
  • 怎么用Python识别手势数字

    2021-11-14 16:35:35
  • asp之家 网络编程 m.aspxhome.com