zoukankan      html  css  js  c++  java
  • mysql事务

    事务:一组sql语句操作单元,组内所有sql语句完成一个业务.注意只有innodb和bdb可以使用事务安全

    如果整组成功则意味着全部sql语句都实现。如果其中任何一个失败,意味着整个操作失败。失败意味着整个过程都是没意义的,数据库应该回到最初始的状态。上面的特性,就是事务。

    如何处理:失败后,可以回到开始位置、没有成功之前,别的用户(进程,对话)是不能看到操作内的数据修改的

    思路:就是在一组操作之前,设计一个记号(备份点)。操作成功就让别人看到数据的修改,如果失败别人就不能看到修改,而且回到记号位置。

    实现:利用innodb存储引擎的事务日志功能。

    sql执行分为2个阶段:一个是执行阶段一个是将执行结果提交到数据库的阶段。其中我们的事务日志,就是保存执行阶段的结果。如果可以用,则将执行的结果提交到数据库

    数据库默认的执行方式是:自动提交(autocommit)。执行完后自动完成提交工作。想要完成事务安全就需要关闭自动提交功能。set autocommit=0;

    例:交班费业务30元:包含两条sql语句update `sm_student` set `s_money`=`s_money`-30 where id=1; update `class` set `c_money`=`c_money`+30 where id=1;

    关闭自动提交后执行update语句本mysql服务器端显示少了30而另一个进程则会显示没有减少。

    在此基础上执行所有的sql语句判断是否成功(出现错误,语法错误或逻辑错误或服务器错误)。成功:结果提交commit 失败:回到开始位置rollback。

    提交commit:这次sql操作执行完毕

    返回rollback:这次sql操作无效返回到开始值

    常见的事务指令:开启事务:start transaction;关闭自动提交,如果事务结束了。成或败它都会将自动提交机制设为初始状态。

    事务特点:原子性(不可拆分)、一致性(数据锁定)、隔离性、持久性 ACID

  • 相关阅读:
    springmvc和struts2的区别(转)
    springmvc和struts2的区别
    sql优化(转)
    java反射机制
    阿里云产品
    vscode 插件推荐
    测试JS方法运行时间
    基于VUE2.0的分页插件(很好用,很简单)
    【软件测试】测试管理工具----禅道
    Vue.js中用webpack合并打包多个组件并实现按需加载
  • 原文地址:https://www.cnblogs.com/dongtong/p/4943572.html
Copyright © 2011-2022 走看看