• mysql事务学习


    mysql事务是什么?

    MySQL 事务主要用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!

    • 在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。
    • 事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。
    • 事务用来管理 insert,update,delete 语句

    在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT 操作。因此要显式地开启一个事务务须使用命令 BEGIN 或 START TRANSACTION,或者执行命令 SET AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。

    MYSQL 事务处理主要有两种方法:

    1. 用 BEGIN, ROLLBACK, COMMIT来实现
    • BEGIN 开始一个事务
    • ROLLBACK 事务回滚
    • COMMIT 事务确认
    1. 直接用 SET 来改变 MySQL 的自动提交模式:

    SET AUTOCOMMIT=0 禁止自动提交
    SET AUTOCOMMIT=1 开启自动提交

    实践

    准备工作:

    • mysql创建数据库test,后建表,添加基础数据
    drop table if exists shiwu;
    CREATE table shiwu
    (
    id int unsigned auto_increment primary key,
    txt int unsigned
    );
    insert into shiwu values(null,11);
    insert into shiwu values(null,22);
    select * from shiwu;
    
    

    使得表内如下:
    sql

    • 为单个语句系列隐式禁用自动提交模式,使用以下START TRANSACTION (或者begin)语句:
    START TRANSACTION;
    SELECT @A:=SUM(txt) FROM shiwu;
    insert into shiwu SET txt=@A;
    COMMIT;
    

    执行结果:
    start transaction
    添加数据完成如下:
    在这里插入图片描述

    • 使用set autocommit
      首先,表内数据初始为:
      select
      执行以下sql:
    set autocommit=0;
    SELECT @A:=SUM(txt) FROM shiwu;
    insert into shiwu SET txt=@A;
    rollback;
    select * from shiwu;
    

    如图,以上sql语句执行完毕,由于rollback; 的执行,将进行事务回滚,所以结果将会回到上一个
    set autocommit

  • 相关阅读:
    OSCache使用指南
    sql性能优化浅谈
    Oracle SQL性能优化
    SQL性能优化
    Linux/Unix笔记本
    Linux/Unix笔记本
    LUOGU P3413 SAC#1
    poj 2393 Yogurt factory(贪心)
    poj 2431 Expedition (贪心)
    LUOGU P3161 [CQOI2012]模拟工厂 (贪心)
  • 原文地址:https://www.cnblogs.com/famine/p/10590088.html
Copyright © 2020-2023  润新知