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

相关文章

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

MySQL错误代码2058和2059的解决办法

《MySQL错误代码2058和2059的解决办法》:本文主要介绍MySQL错误代码2058和2059的解决办法,2058和2059的错误码核心都是你用的客户端工具和mysql版本的密码插件不匹配,... 目录1. 前置理解2.报错现象3.解决办法(敲重点!!!)1. php前置理解2058和2059的错误

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

MySQL Workbench 安装教程(保姆级)

《MySQLWorkbench安装教程(保姆级)》MySQLWorkbench是一款强大的数据库设计和管理工具,本文主要介绍了MySQLWorkbench安装教程,文中通过图文介绍的非常详细,对大... 目录前言:详细步骤:一、检查安装的数据库版本二、在官网下载对应的mysql Workbench版本,要是

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

浅谈mysql的sql_mode可能会限制你的查询

《浅谈mysql的sql_mode可能会限制你的查询》本文主要介绍了浅谈mysql的sql_mode可能会限制你的查询,这个问题主要说明的是,我们写的sql查询语句违背了聚合函数groupby的规则... 目录场景:问题描述原因分析:解决方案:第一种:修改后,只有当前生效,若是mysql服务重启,就会失效;

MySQL多列IN查询的实现

《MySQL多列IN查询的实现》多列IN查询是一种强大的筛选工具,它允许通过多字段组合快速过滤数据,本文主要介绍了MySQL多列IN查询的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析与优化1.

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作