并发带来的问题 1.脏读dirty read 脏读的问题是transaction读到了没有被提交的数据.例如,T1更新了data1,还没提交,这时T2读取了更新后的data1, 用于计算和更新别的值, 然后T1又回滚了data1. 如果是隔离级别是read commited, 那么T1就会对data1加exclusive lock, T2要等待T1释放锁才能读取到,就避免了脏读. 2. 不可重复读 nonrepeatable read, 不可重复读就是, transaction每次读一行都会得到…
Oracle锁大类 1.DML锁 (SELECT, INSERT, UPDATE, DELETE, MERGE是对数据库加的锁, 可能是行锁,也可能是表锁) 2.DDL锁 (Create, Alter时对数据库加的锁, 保护对象结构定义) 3.内部锁和闩latch DML锁 TX锁(事物锁), 事物开始时持有这个锁,知道事物提交或回滚. 注意:Oracle锁不会对系统带来更多的开销,原因是Oralce没有一个传统的锁管理器. 通过查询V$transaction, v$session, v$loc…
本文主要内容 1.transaction的可串行化 2.数据库并发带来的问题, dirty read, Nonrepeatable reads, Phantoms幻读 3.隔离级别和2中的问题 4. 悲观锁和乐观锁 5. 锁类型,DML锁,DDL锁,闩,手动锁和用户定义锁 什么是transaction可串行化 通常,不管数据库初态怎样,一个调度对数据库状态的影响都和某个串行调度相同,我们就说这个调度是可串行化的. 理想情况下,transaction就应该是可串行化的. 意思就是几个transac…
Mysql知识实在太丰富了,前几天百度的面试官问我MySql在Repeatable Read下面是否会有幻读出现,我说按照事务的特性当然会有, 但是面试官却说 Mysql 在Repeatable Read底下 也不会发生幻读的情况,因为Mysql有间隙锁的可以防止幻读: 我一头雾水,啥叫间隙锁.以下就是Mysql如何利用间隙锁防止幻读的总结: 我们都知道Mysql,Oracle PostgreSQL 可以利用MVCC来处理事务,防止加锁,来提高访问效率 MVCC只是工作在两种事务级别底下:(a)…
 事务提交过程 事务 基本概念 概念:一个或者多个DML语言组成 特点:要么都成功.要么都失败 事务的隔离性:多个client同一时候操作数据库的时候.要隔离它们的操作, 否则出现:脏读  不可反复读  幻读 Oracle默认情况下,事务是打开的 commit案例: SQL> create table t1(tid int,tname varchar2(20)); 表已创建. SQL> select * from tab; TNAME                          TA…
当涉及到两个或多个线程操作同一个资源时,就会出现锁的问题. 数据库中的某一条记录或者是某一个对象中的字段,可以修改,也可以读取,一般情况下,读取的那个方法应该加锁(即用synchronized互斥),而读取的那个方法则不需要加锁.允许多个线程同时读取,而不允许同时进行修改.对应的数据库事务隔离级别应该是:read committed,即可以避免读取到脏数据,但是不可重复读. 关于事务的隔离级别,感觉这篇文章介绍的不错: http://www.linuxidc.com/Linux/2013-06/…
1:mysql的事务隔离级别查看方法 mysql 最简单,执行这条语句就行:select @@tx_isolation  详情: 1.查看当前会话隔离级别 select @@tx_isolation; 2.查看系统当前隔离级别 select @@global.tx_isolation; 3.设置当前会话隔离级别 set session transaction isolatin level repeatable read; 4.设置系统当前隔离级别 set global transaction i…
回归一下事务的四大特性ACID 1.原子性(Atomicity) 事务开始后所有操作,要么全部做完,要么全部不做.事务是一个不可分割的整体.事务在执行过程中出错,会回滚到事务开始之前的状态,以此来保证事务的完整性.类似于原子在物理上的解释:指化学反应不可再分的基本微粒,原子在化学反应中不可分割 . 2.一致性(Consistency) 事务在开始和结束后,能保证数据库完整性约束的正确性即数据的完整性.比如经典的转账案例,A向B转账,我们必须保证A扣了钱,B一定能收到钱.个人理解类似于物理上的能量…
订单并发这个问题我想大家都是有一定认识的,这里我说一下我的一些浅见,我会尽可能的让大家了解如何解决这类问题. 在解释如何解决订单并发问题之前,需要先了解一下什么是数据库的事务.(我用的是mysql数据库,这里以mysql为例) 1)     事务概念 一组mysql语句,要么执行,要么全不不执行. 2)  mysql事务隔离级别 Read Committed(读取提交内容) 如果是Django2.0以下的版本,需要去修改到这个隔离级别,不然乐观锁操作时无法读取已经被修改的数据 Repeatabl…
1.锁 为什么需要锁?因为数据库要解决并发控制问题.在同一时刻,可能会有多个客户端对表中同一行记录进行操作,比如有的在读取该行数据,其他的尝试去删除它.为了保证数据的一致性,数据库就要对这种并发操作进行控制,因此就有了锁的概念. 1.1锁的分类 从对数据操作的类型(读\写)分 读锁(共享锁):针对同一块数据,多个读操作可以同时进行而不会互相影响. 写锁(排他锁):当前写操作没有完成前,它会阻断其他写锁和读锁. 大多数时候,MySQL锁的内部管理都是透明的. 1.2锁粒度(Lock granula…