笔记记录自林晓斌(丁奇)老师的<MySQL实战45讲> 3) --事务隔离,为什么你改了我还看不见? 简单来说,事务就是要保证一组数据操作,要么全部成功,要么全部失败.在MySQL中,事务支持是在引擎层实现的.但并不是所有的引擎都支持事务,这也是MyISAM被InnoDB取代的重要原因之一. 本篇内容均是在InnoDB下讨论. 提到事务,总免不了ACID(Atomicity,Consistency,Isolation,Durability),(原子性,一致性,隔离性,持久性),本篇主要讨论的是…
提到事务,你肯定不陌生,和数据库打交道的时候,我们总是会用到事务.最经典的例子就是转账,你要给朋友小王转100块钱,而此时你的银行卡只有100块钱. 转账过程具体到程序里会有一系列的操作,比如查询余额.做加减法.更新余额等,这些操作必须保证是一体的,不然等程序查完之后,还没做减法之前,你这100块钱,完全可以借着这个时间差再查一次,然后再给另外一个朋友转账,如果银行这么整,不就乱了么?这时就要用到“事务”这个概念了. 简单来说,事务就是要保证一组数据库操作,要么全部成功,要么全部失败.在MySQ…
一文了解MySQL性能测试及调优中的死锁处理方法,你还看不明白? 以下从死锁检测.死锁避免.死锁解决3个方面来探讨如何对MySQL死锁问题进行性能调优. 死锁检测 通过SQL语句查询锁表相关信息: (1)查询表打开情况 SHOW OPEN TABLES WHERE IN_USE> 0 (2)查询锁情况列表 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS (3)查询锁等待信息,其中blocking_lock_id是当前事务在等待的事务 SELECT *…
文章部分图片和总结来自参考资料,侵删 概述 MySQL的可重复读隔离级别,事务T启动的时候会创建一个视图read-view,之后事务T执行期间,即使有其他事务修改了数据,事务T看到的仍然跟在启动时看到的一样.**也就是说,一个在可重复读隔离级别下执行的事务,好像与世无争,不受外界影响. 可重复读的含义 一个事务启动的时候,能够看到所有已经提交的事务结果.但是之后,这个事务执行期间,其他事务的更新对它不可见. read-view 到底是什么     假如有多个事务,每个事务都生成一个数据的全量拷贝…
参考: 数据库技术:MySql学习笔记之事务隔离级别详解 详解MySQL 数据库隔离级别与MVCC MySQL 事务&&锁机制&&MVCC 数据库系统原理 - MySQL封锁 数据库常见面试题:乐观.悲观锁,行锁.表锁.读.写锁,间隙锁 MySQL中的锁(表锁.行锁) 数据库系统概念-读写锁.意向锁.行表锁 mysql的锁机制是悲观_一文带你了解 MySQL 中的各种锁机制! 每天一个知识点:"快照"在 MVCC 里是怎么工作的? MVCC一致性视图 -…
MySqlInnoDB的事务隔离级别有四个:(默认是可重复读repeatable read) 未提交读 read uncommit : 在另一个事务修改了数据,但尚未提交,在本事务中SELECT语句可能会查询到这些未被提交的数据,而发生脏读. 提交读 read commit : 在一个事务中发生两次SELECT查询,当第一次SELECT执行完查询到一些数据,接下来另一个事务修改了这些数据并提交了,当第二次SELECT执行的时候查询到的数据和第一次SELECT的不同,而发生不可重复读.幻读问题,但…
前言 数据库是一个共享资源,为了充分利用数据库资源,发挥数据 库共享资源的特点,应该允许多个用户并行地存取数据库.但这样就会产生多个用户程序并 发存取同一数据的情况,为了避免破坏一致性,所以必须提供并发控制机制. 并发控制是以事务(transaction)为单位进行的. 什么时候表锁什么时候行锁? 行锁是指的innodb引擎,只有通过索引条件检索数据,InnoDB才会使用行级锁,否则,InnoDB将使用表锁. 查看表锁 #查看是否有锁表的情况 show OPEN TABLES where In_…
简单来说,事务就是要保证一组数据库操作,要么全部成功,要么全部失败.在MySQL中,事务至此是在引擎层实现的,但并不是所有的MySQL引擎都支持事务,这也是MyISAM被InnoDB取代的原因之一. 隔离性与隔离级别 提到事务,想到的是ACID(原子性,一致性,隔离性,持久性) 原子性:原子性操作就是这个事物执行要么成功,要么失败.将整个过程看作是一个不可分割的整体. 一致性:一致性指的是一个事务在执行前后其状态一致.比如你和小明各有100元,无论你俩之间相互借还多少钱加起来都是200.这就是事…
03.Webpack的强大功能 一.生成Source Maps(使调试更容易) 通过简单的配置,webpack就可以在打包时为我们生成的source maps,这为我们提供了一种对应编译文件和源文件的方法,使得编译后的代码可读性更高,也更容易调试. 需要配置devtool,它有以下四种不同的配置选项,各具优缺点,描述如下: devtool选项 配置结果 source-map 在一个单独的文件中产生一个完整且功能完全的文件.这个文件具有最好的source map,但是它会减慢打包速度: cheap…
※存储过程存储过程是保存在数据库上的一段可执行代码.1.定义存储过程的语法是:Create procedure sp_name (参数..)Begin SQL语句End;2.调用它的方法:Call sp_name(参数-); //空参时则括号中不填内容 3.演示1)不带参数定义(delimiter用于定义结束符):DELIMITER $$CREATE PROCEDURE p1()BEGIN INSERT INTO person2 VALUES('P05','李四',0); SELECT * FR…