zoukankan      html  css  js  c++  java
  • 了解mysql-事务介绍

    事务

    是什么

    事务由单独单元的一个或多个SQL语句组成,在这个单元中,每一个mysql语句是相互依赖的;由于整个单独单元作为不可分割的整体,那么如果单元中某条SQL语句一旦执行失败或产生失败,整个单元就会回滚。要么全部成功,要么全部失败。

    在mysql中用的最多的存储引擎有:innodb,myisam,memory 等。其中innodb支持事务,而myisam、memory等不支持事务

    查看mysql支持的引擎:SHOW engines
    

    事务的四大特性

    1. 原子性:要么成功,要么失败。
    2. 一致性:状态与其他业务规则保持一致。
    3. 隔离性:在并发中使用。一个事务不被另一个事务所影响
    4. 持久性:一旦改变提交之后,数据就持久化被操作了。

    分类

    隐式事务:没有明显的开启和结束标记
    显式事务:有明显的开启和结束标记
    
    

    使用步骤:

    插个小知识

    DDL(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等;
    DML(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据);
    DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;
    DQL(Data Query Language):数据查询语言,用来查询记录(数据)。
    
    
    • 一般情况下,如果在一个事务中包含多个SQL语句,那么就要开启事务和结束事务;
    开启事务:start transaction;
    结束事务:commit或rollback。
    
    
    • 开始是以第一个DML语句执行开始

    • 以下面的其中之一作为结束:
      COMMIT 或ROLLBACK 语句(回滚,即回滚到事务的起点,之前做的所有操作都被撤消了!)
      DDL 或DCL 语句(自动提交)
      用户会话正常结束
      系统异常终了

    • START TRANSACTION; # 开启
      UPDATE account SET balance=balance-10000 WHERE id=1;
      UPDATE account SET balance=balance+10000 WHERE id=2;
      COMMIT; # 正常结束
      
      
  • 相关阅读:
    【全程NOIP计划】分治与倍增
    apple id 后端验证 django
    安装Tomcat8,在Eclipse中配置Tomcat8
    CURL并发测试POST和DELETE请求
    curl如何发起DELETE/PUT请求?(备忘)
    Ubuntu 11.10下安装配置Zend Studio 9.0破解版详细步骤
    RTP QOS
    RTCP
    DirectDraw基础篇
    RTSP简介
  • 原文地址:https://www.cnblogs.com/yhycoder/p/12545193.html
Copyright © 2011-2022 走看看