前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >MySQL 事物

MySQL 事物

作者头像
房上的猫
发布于 2018-03-14 04:50:48
发布于 2018-03-14 04:50:48
1.5K00
代码可运行
举报
文章被收录于专栏:个人随笔个人随笔
运行总次数:0
代码可运行

事务是数据库处理操作,其中执行就好像它是一个单一的一组有序的工作单元。换言之,事务将永远不会是完全的,除非在组内每个单独的操作是成功的。如果事务中的任何操作失败,整个事务将失败。

实际上,许多SQL查询组成到一个组,将执行所有这些一起作为事务的一部分。

1.概念

一条或者多条sql语句的集合!  事务:就是一堆操作的集合,他们同生共死。要么都执行成功,要么都执行失败 2.事务的特性  ACID   A:原子性  完整的,不可分割的

  原子性 (Atomicity):在事务中的操作,要么都执行,要么都不执行!

  C: 一致性  事务执行完毕后,数据的状态是一致的()

  一致性(Consistency):事务必须保证数据库从一个一致性的状态变成另一个一致性的状态!

  I: ISOLation 隔离性  两个事务执行互不影响

  隔离性(Isolation):每个事务之间互不干扰!哪怕是并发执行也不干扰!

  D: 永久性  事务执行完后,对数据的影响是永久的。

  持久性(Durability):事务一旦被改变,那么对数据库中数据的影响是永久性的!

3.事务操作的关键字   自动提交事务开关set autocommit=0   开始事务 start transaction /begin   提交事务 commit   回滚事务 rollback   set autocommit=1 4.事务+++存储过程 转账的例子

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
DELIMITER $$
CREATE PROCEDURE usp_transfer() 
    BEGIN  
    ##错误总数默认是0
    DECLARE t_error INTEGER DEFAULT 0;  
    ## continue 继续  hanlder 执行   并且对 t_error重新赋值为1
    DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error=1;  
    SET autocommit=0;
        START TRANSACTION;  
        UPDATE bank SET balance=balance-100 WHERE cid=1;    
        UPDATE bank SET balance =balance+100 WHERE cid=2;
        IF t_error > 0 THEN  
            ROLLBACK;  
        ELSE  
            COMMIT;  
        END IF;  
     SET autocommit=1; 
    END$$  
DELIMITER ;  
 
CALL test_sp800()
 

定义一个存储过程的最简易的语法是

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
delimiter $$
create procedure usp_stulist()
begin
  select * from student
end$$
delimiter;

 存储过程详解将在:http://www.cnblogs.com/lsy131479/p/8463804.html   中详细介绍

          模拟 银行转账!                          

--   创建数据库

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE DATABASE  myBank;

--  切换指定的数据库

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
USE myBank;

--  创建表

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE  TABLE  IF NOT  EXISTS bank(
customerName  VARCHAR(10) NOT NULL  COMMENT '用户名',
currentMoney  DECIMAL(10,2) NOT NULL  COMMENT '账户余额'
);

-- 插入数据

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
INSERT INTO bank  VALUES('小黑',50000),('小白',500000);

--  小黑  给小白  转账10000 --   修改两条数据 --    01.小黑-10000 --    02.小白+10000

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
UPDATE bank SET currentMoney=currentMoney-10000
 WHERE customerName='小黑';
 --  故意写错字段名称  让02  报错
UPDATE bank SET currentMoneysss=currentMoney+10000
 WHERE customerName='小白';
 

--  开启事务   START TRANSACTION 或者 BEGIN --  01.02  为一个事务

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
BEGIN
 UPDATE bank SET currentMoney=currentMoney-10000
 WHERE customerName='小黑';
 UPDATE bank SET currentMoneysss=currentMoney+10000
 WHERE customerName='小白';

--  事务回滚  ROLLBACK --  提交事务 COMMIT

UPDATE bank SET currentMoney=500000  WHERE customerName='小黑'; --  证明mysql是默认提交事务的!

SET  autocommit=0(关闭事务自动提交) | 1(开启事务自动提交)

-- 关闭事务自动提交 

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SET  autocommit=0;
BEGIN;   --  开启事务
 UPDATE bank SET currentMoney=currentMoney-10000
 WHERE customerName='小黑';
 UPDATE bank SET currentMoney=currentMoney+10000
 WHERE customerName='小白';
COMMIT;  --  手动提交事务
  UPDATE  bank SET currentMoney=10000;
ROLLBACK;   -- 事务回滚
SET  autocommit=1;  -- 恢复自动提交
 
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
事务、视图、锁表
事务(TRANSACTION)是作为单个逻辑工作单元执行的一系列操作 多个操作作为一个整体向系统提交,要么都执行、要么都不执行 事务是一个不可分割的工作逻辑单元
用户9979303
2022/10/28
6520
MySql事务、索引和备份
事务就是将一组SQL语句放在同一批次内去执行,只要一个SQL语句出错,则该批次内的所有SQL都将被取消执行。
用户10175992
2022/11/15
5130
MySql事务、索引和备份
MySQL的事务概念
我们规定了,做一件事情,只有成功和失败! 用个很经典的例子举例: 银行转账,A向B转账十万,能不能发生一遍付钱一边没收钱的情况? 现实中一定是A和B同时成功或者失败,不能出现一边成功另一边失败的情景,这就是事务的简单例子。
向着百万年薪努力的小赵
2022/12/02
5830
transaction (2)—mysql进阶(五十八)
上篇文章说了acid四个事务的特性,原子性保证要不两个sql一起执行,要么不执行,隔离性,两个事务之间必须互不干扰,一致性,两边的数据必须保持一致,可以说一致性的前提是原子性和隔离性必须正常,但原子性和隔离性都正常,就能保证一致性吗?并不是,还必须满足其他一些约束,比如金额不能为负数。持久性就是必须持久化到磁盘才算事务成功。
用户9919783
2022/07/29
3730
【数据库】MySQL:ACID特性、隔离级别及实战操作
MySQL 中的事务是数据库管理系统中用来确保多个 SQL 操作以原子性的方式执行的机制。事务可以保证一系列操作要么全部成功,要么全部失败,从而保证数据库的一致性和完整性。
易辰君
2024/11/07
2310
浅谈 SQL Server 查询优化与事务处理
之前我们简单了解了各种查询的用法,然而在实际开发中还会用到一些比较高级的数据处理和查询,包括索引、视图、存储过程和触发器。从而能够更好地实现对数据库的操作、诊断及优化。
小手冰凉
2019/09/10
2K0
浅谈 SQL Server 查询优化与事务处理
MySQL 事务和 MVCC 机制
了解事务之前,先来看看数据库为什么需要有事务,假设没有事务会有什么影响?假设我们有一个银行账户系统,表结构如下:
Se7en258
2021/07/01
5000
MySQL--事务
mysql默认自动事务提交,事务面对增,删,改操作时的一种控制手段,当面对一次操作多条记录,或都多个连接同时操作一条记录时的统一性管理手段,控制的是,增,删,改操作是否有效
用户10787181
2023/10/28
2120
MySQL--事务
循序渐进 MySQL 事务隔离级别
事务简言之就是一组 SQL 执行要么全部成功,要么全部失败。MYSQL 的事务在存储引擎层实现。
波罗学
2019/07/31
4850
MySQL基础之事务编程学习笔记
在学习《MySQL技术内幕:SQL编程》一书,并做了笔记。本博客内容是自己学了《MySQL技术内幕:SQL编程》事务编程一章之后,根据自己的理解做的笔记,内容和书本并不一致,不过书本实验都经过自己验证,基于MySQL5.7版本。做笔记的目的是方便自己复习,同时分享出来或许对其他人或许有点帮助
SmileNicky
2020/01/13
4700
MySQL基础之事务编程学习笔记
一文精通MySQL事务规则
引言:每个程序员学习数据库离不开MySQL,而学习MySQL就必学事务,今天我们就来一起学习一下MySQL的事务;
框架师
2020/03/31
7860
一文精通MySQL事务规则
MySQL 事务
  事务(Transaction),一般是指要做的或所做的事情。在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)。事务通常由高级数据库操纵语言或编程语言(如 SQL,C++ 或 Java)书写的用户程序的执行所引起,并用形如 begin transaction 和 end transaction 语句或函数调用来界定。事务由事务开始(begin transaction)和事务结束(end transaction)之间执行的全体操作组成。在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。一般用来管理 insert,update,delete 语句。
Demo_Null
2020/09/28
2.1K0
MySQL 事务
数据库MySQL-事务
原子性(Atomicity):事务是一个完整的操作。事务的各步操作是不可分的(原子的);要么都执行,要么都不执行
cwl_java
2020/03/27
1K0
05 基础的数据操作
以上4 种操作又简称为 CURD (Create ,Update ,Retrieve ,Delete )
用户9184480
2024/12/13
880
数据库事务
如果在执行一个业务操作的时候,需要执行多条SQL语句,必须保证所有的SQL语句都执行成功。只要其中有一条执行失败,则所有的SQL语句都要进行回滚
Devops海洋的渔夫
2021/03/12
7210
数据库事务
8-TCL事务控制语言
一个或一组sql语句组成的一个执行单元,这个执行单元要么全部执行,要么全部不执行。每条sql语句都是相互依赖的 整个单元作为一个不可分割的整体,如果单元中某条sql语句执行失败或者产生错误,则整个单元将会回滚。所有收到影响 的数据将会返回到事务开始以前的状态。如果单元内所有语句均正常执行,则事务被成功执行
Ywrby
2022/10/27
7090
走向面试之数据库基础:三、SQL进阶之变量、事务、存储过程与触发器
  SELECT 以表格的方式输出,可以同时输出多个变量;而PRINT 则是以文本的方式输出,一次只能输出一个变量的值。
Edison Zhou
2018/08/20
1.3K0
走向面试之数据库基础:三、SQL进阶之变量、事务、存储过程与触发器
第13章_事务基础知识
🧑个人简介:大家好,我是 shark-Gao,一个想要与大家共同进步的男人😉😉
程序员Leo
2023/08/02
2180
第13章_事务基础知识
【愚公系列】2022年01月 Mysql数据库-事务
文章目录 一、MySQL事务 1.事务的概念 2.事务的数据准备 3.未管理事务演示 4.管理事务演示 5.事务的提交方式 6.事务的四大特征(ACID) 7.事务的隔离级别 8.事务隔离级别演示 9.隔离级别总结 10.事务的总结 一、MySQL事务 1.事务的概念 一条或多条 SQL 语句组成一个执行单元,其特点是这个单元要么同时成功要么同时失败,单元中的每条 SQL 语句都相互依赖,形成一个整体,如果某条 SQL 语句执行失败或者出现错误,那么整个单元就会回滚,撤回到事务最初的状态,如果单元中所有的
愚公搬代码
2022/01/28
3630
MySQL数据库——事务的操作(开启、回滚、提交)、特征、隔离级别基础总结
如果一个包含多个步骤的业务操作,被事务管理,那么这些操作要么同时成功,要么同时失败。如下A给B转钱的例子很形象的说明了事务的概念:
Winter_world
2020/09/25
20.9K0
MySQL数据库——事务的操作(开启、回滚、提交)、特征、隔离级别基础总结
相关推荐
事务、视图、锁表
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文