mysql事务管理操作详解
网络编程 2021-07-05 14:37www.168986.cn编程入门
这篇文章主要介绍了mysql事务管理操作,结合实例形式详细分析了mysql事务管理相关特性、原理及回滚操作注意事项,需要的朋友可以参考下
本文实例讲述了mysql事务管理操作。分享给大家供大家参考,具体如下
本文内容
- 什么是事务管理
- 事务管理操作
- 回滚点
- 默认的事务管理
首发日期2018-04-18
什么是事务管理
- 可以把一系列要执行的操作称为事务,而事务管理就是管理这些操作要么完全执行,要么完全不执行(很经典的一个例子是A要给B转钱,A的钱减少了,突然的数据库断电了,导致无法给B加钱,然后由于丢失数据,B不承认收到A的钱;在这里事务就是确保加钱和减钱两个都完全执行或完全不执行,如果加钱失败,那么不会发生减钱)。
- 事务管理的意义保证数据操作的完整性。
- mysql中并不是所有的数据引擎都支持事务管理的,只有innodb支持事务管理。
事务管理的特性
- 原子性事务的整个操作是一个整体,不可以分割,要么全部成功,要么全部失败。
- 一致性事务操作的前后,数据表中的数据没有变化。
- 隔离性事务操作是相互隔离不受影响的。
- 持久性数据一旦提交,不可改变,永久的改变数据表数据。
事务管理操作
- 开启事务管理开启之后,狼蚁网站SEO优化的sql语句并不会马上执行并把结果写到表中,而是会写到事务日志中。
- start transaction;
- 回退操作回退会清掉开始事务管理之后写到事务日志中的内容,即恢复到开启事务管理之前。
- 语法rollback;
- 注意回退操作只是回退"写"的内容,对于普通的读表select语句不能回退。
- 事务提交将sql语句的结果写到数据表中。
- 语法mit:
实验表
create table bankaount(id int primary key auto_increment,name varchar(15),money int); insert into bankaount(name,money) values("Jobs",2000); insert into bankaount(name,money) values("Bill",3000);
补充
- 当 mit 或 rollback 语句执行后,事务会自动关闭(将来的更改会隐含提交)。
- 锁机制在事务操作一个表时,如果使用索引来取值,那么会锁定到对应行;如果没有使用索引来取值,那么会锁定整个表。锁定之后其他连接无法操作指定行或表。
回滚点
- 回滚点可以指定rollback回退的位置【比如现在打了100条命令,发现第81打错了,如果回滚到打了81命令之前一点而不是回滚到开启事务之前就可以节省下很多时间。】
- 语法
- 创建回滚点savepoint 回滚点名;
- 回滚到回滚点rollback to 回滚点名;
补充:
- 回滚点在事务管理关闭(rollback或mit之后)之后失效,不要在事务之外使用回滚点。
默认的事务管理
- 默认情况下,mysql的事务管理是关闭(自动事务)的,语句的结果会马上写到数据表中。
- 可以通过show variable like 'automit';来查看是否开启自动事务,值为1为自动事务已开启,为0则为关闭。
- 关闭自动事务set automit =0;【关闭后需要mit来执行每一条语句,相当于开始了事务管理】
- 不过注意的是set automit针对的是会话变量,所以这个设置只在此次会话连接中生效。
更多关于MySQL相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》、《》及《》
希望本文所述对大家MySQL数据库计有所帮助。
上一篇:mysql游标的原理与用法实例分析
下一篇:简单了解mysql语句书写和执行顺序
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程