mysql事务对效率的影响的分析

1、数据库事务会降低数据库的性能。为了保证数据的一致性和隔离性,事务需要锁定事务。

2、如果其他事务需要操作这部分数据,必须等待最后一个事务结束(提交,回滚)。

实例

create table acct(
  acct_no varchar(32),
  acct_name varchar(32),
  balance decimal(16,2)
);

insert into acct values
  ('0001','Jerry', 1000),
  ('0002','Tom', 2000);

start transaction; -- 启动事务
update acct set balance = balance - 100 where acct_no = '0001'; -- 模拟扣款人
update acct set balance = balance + 100 where acct_no = '0002'; -- 模拟收款人
commit; -- 事务提交
rollback; -- 事务回滚

知识点扩展:

事务

  • 原子性:整个事务的所有操作要么全部提交成功,要么全部失败回滚
  • 一致性:指事务将数据库从一种一致性状态转换到另外一种一致性状态,在事务开始之前和事务结束后数据库中的完整性没有被破坏
  • 隔离性:要求一个事务对数据库中数据修改,在未提交完成前对其他事务是不可见的
  • 持久性:一旦事务提交,则其所做的修改就会永久保存到数据库中。此时即使系统崩溃,已经提交的修改数据也不会丢失。

大事务

运行时间比较长,操作的数据比较多的事务

  • 锁定太多的数据,造成大量的阻塞和锁超时
  • 回滚时所需时间比较长
  • 执行时间长,容易造成主从延迟

如何处理大事务:

  • 避免一次处理太多的数据
  • 移出不必要在事务中的select操作

关于mysql事务对效率的影响分析总结的文章就介绍至此,更多相关mysql事务对效率的影响内容请搜索编程宝库以前的文章,希望大家多多支持编程宝库

 联合查询之unionunion可以合并两个以上 select语句查询出来的表,并消除表中的重复行。其中,select语句需要拥有相同数量和相同数据类型的列。1. 查询中国各省的ID以及省份名称sele ...