MySql 事务练习

2024-09-09 05:20
文章标签 mysql 练习 事务 database

本文主要是介绍MySql 事务练习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        事务(transaction)

-- 事务 transaction
-- 事务是一组操作的集合,是一个不可分割的工作单位,事务会将所有的操作作为一个整体一起向系统提交或撤销请求
-- 事务的操作要么同时成功,要么同时失败
-- MySql的事务默认是自动提交的,当执行一个DML语句,MySql会立即自动隐式提交事务-- 常见案例:银行转账
-- 逻辑:A给B转账1000:1.查询A账户的余额 2.A账户余额 - 1000 3.B账户余额 + 1000
-- 这三步只能同时成功,或者同时失败;所以说这三步操作要成为一个事务-- 数据准备
create table account(id int auto_increment primary key comment '主键ID',name varchar(10) comment '姓名',money int comment '余额'
) comment '账户表';
insert into account(id, name, money) VALUES (null,'张三',2000),(null,'李四',2000);
commit;-- 恢复数据
update account set money = 2000 where name = '张三' or name = '李四';
commit;-- 事务的两种方式
-- 1.设置事务为手动提交
set @@autocommit = 0;
set @@autocommit = 1;
select @@autocommit;-- 执行转账逻辑(成功完成)
select money from account where name = '张三';
update account set money = money - 1000 where name = '张三';
update account set money = money + 1000 where name = '李四';-- 执行转账逻辑(转账失败)
select money from account where name = '张三';
update account set money = money - 1000 where name = '张三';
update account set money = money + 1000 where name = '李四';
-- 失败示例:转账失败!update account set money = money + 1000 where name = '李四';
-- 通过事务的回滚,成功保证了数据的完整、正确-- 事务若全部执行成功,那么commit
commit;
-- 若事务执行过程中有异常,那么回滚事务
rollback;-- 2.用开启事务的方式
-- start transaction 或 begin
start transaction;-- 执行转账逻辑
select money from account where name = '张三';
update account set money = money - 1000 where name = '张三';
update account set money = money + 1000 where name = '李四';
-- 转账失败!update account set money = money + 1000 where name = '李四';-- 成功则提交,失败则回滚
commit;rollback;-- 事务的四大特性
-- 1.原子性(Atomicity):事务是不可分割的最小操作单元,要么全部成功;要么全部失败
-- 2.一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态
-- 3.隔离性(Isolation):数据库系统提供事务隔离机制,保证事务在不受外部并发操作影响的独立环境下运行
-- 4.持久性(Durability):事务一旦完成,对于数据库中的数据改变是永久的-- 并发引起的事务问题
-- 脏读:由于多线程,一个事务读取到了另外一个事务还没提交的数据
-- 不可重复读:一个事务先后读取同一条记录,但是两次读取的数据不同
-- 幻读:一个事务查询数据时,没有对应的数据行;但是在插入数据时,发现该数据行已经存在了,仿佛一个幻影-- 事务隔离级别:隔离级别越高,性能越差(性能和安全性需要综合考虑)
-- Read uncommited:最低的隔离级别,不能解决并发引起的事务问题
-- Read commit(Oracle的默认隔离级别):Oracle默认的隔离级别,可以解决脏读问题
-- Repeatable Read(MySql的默认隔离级别):MySql默认的隔离级别,可以解决脏读、不可重复读的问题
-- Serializable:最高的隔离级别,可以解决一切并发引起的事务问题-- 查看事务的隔离级别
select @@transaction_isolation;
-- 设置事务的隔离级别
-- set [session|global] transaction isolation level {隔离级别}   | session是当前对话;global是全部对话-- 存储引擎
-- 查看可以使用的存储引擎
show engines;
-- 默认存储引擎
-- INNODB
-- INNODB和MylSAM的区别:INNODB支持事务、外键、行级锁-- 绝大部分情况都是使用INNODB引擎,其可以保证数据的完整性,数据安全;存储核心数据
-- MylSAM一般存储非核心的数据,不太能保证安全性

这篇关于MySql 事务练习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1150277

相关文章

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

MySQL多实例管理如何在一台主机上运行多个mysql

《MySQL多实例管理如何在一台主机上运行多个mysql》文章详解了在Linux主机上通过二进制方式安装MySQL多实例的步骤,涵盖端口配置、数据目录准备、初始化与启动流程,以及排错方法,适用于构建读... 目录一、什么是mysql多实例二、二进制方式安装MySQL1.获取二进制代码包2.安装基础依赖3.清

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运