数据库表锁和行锁

页级锁:引擎BDB。mysql

表级锁:引擎MyISAM,锁住整个表,能够同时读,写不行。web

行级锁:引擎InnoDB,单独的一行记录加锁。sql

表级,直接锁定整张表,在锁按期间,其余进程没法对该表进行写操做。若是你是写锁,则其余进程没法进行读操做。数据库

行级,仅对指定的记录进行加锁,这样其余进程仍是能够对同一张表中其余的记录进行操做。多线程

页级,表锁速度快,但冲突多,行级锁冲突少,但速度慢。因此取了折中的页级,一次锁定相邻的一组记录。并发

mysql5.1支持对MyISAM和MEMORY进行表级锁定,对BDB进行页级锁定,对InnoDB进行行级锁定。性能

 

对于write,mysql使用的表锁定方法原理以下:线程

若是在表上没有锁,在它上面放一个写锁。不然,把锁定请求放在写锁定队列中。索引

对read,mysql使用的锁定方法原理以下:队列

若是在表上没有写锁定,把一个读锁定放到它上面。不然,把锁清秋放在读锁定队列中。

 

InnoDB使用行锁定,BDB使用页锁定。对于这两种存储引擎,对可能存在死锁。这是由于在sql语句处理期间,InnoDB自动得到行锁定和BDB得到页锁定,而不是在事务启动时得到。

行锁定的优势:

一、当在许多线程中访问不一样的行时只存在少许锁定冲突。

二、回滚时只有少许的更改。

三、能够长时间锁定单一的行

行级锁定的缺点:

一、比页级或表级锁定占用更多的内存。

二、当在表的大部分中使用时,比页级或表级锁定速度慢,由于必须获取更多的锁。

三、若是在大部分数据上常常进行GroupBY操做或者必须常常扫描整个表,比其余锁定明显慢不少。

四、用高级别锁定,经过支持不一样的类型锁定,也能够很容易调节应用程序,由于其锁成本小于行级锁定。

在如下状况,表锁定优先页级或行级锁定:

一、表的大部分语句用于读取。

二、对严格的关键字进行读取和更新,能够用单一的读取关键词来提取一行。

三、select结合并行的insert语句,而且只有不多的update或delete语句。

四、在整个表上有许多扫描或groupby操做,没有任何写操做。

===============mysql锁表类型和解锁语句========================

若是想要在一个表上作大量的insert和select操做,可是并行的插入却不可能时,能够江榉路插入到临时表中,而后按期将临时表中的数据更新到实际的表里。命令:

mysql>LOCK TABLE real_table WRITE,insert_table WRITE;

mysql>INSERT INTO real_table select * from insert_table;

mysql>TRUNCATE TABLE insert_table;

mysql>UNLOCK TABLES;

行级锁的优势:

一、在不少线程请求不一样记录时减小冲突锁。

二、事务回滚时减小改变数据。

三、使长时间对单独的一行记录加锁成为可能。

行级锁的缺点:比页级锁和表级锁小号更多的内存。

锁是计算机协调多个进程或线程并发访问某一资源的机制,不一样的数据库的锁机制大同小异。因为数据库资源是一种供不少用户共享的资源,因此如何保证数据并发访问的一致性、有效性是全部数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的重要因素。了解锁机制不只可使咱们更有效的开发利用数据库资源,也使咱们可以更好地维护数据库,从而提升数据库的性能。

mysql的锁机制比较简单,其显著的特色是不一样的存储引擎支持不一样的锁机制。

例如:MyISAM和MEMORY存储引擎采用的是表级锁;BDB存储引擎采用的是页面锁,同时也支持表级锁;InnoDB存储引擎即支持行级锁,也支持表级锁,默认是采用行级锁。

以上三种锁的特性可大体概括以下:

1)表级锁:开销小,加锁快;不会出现死锁,锁定粒度大,发生锁冲突的几率最高,并发度最低。

2)行级锁:开销大,加锁慢;会出现死锁,锁定粒度小,发生锁冲突的几率最低,并发度也最高。

3)页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度通常。

三种锁各有特色,若仅从锁的角度来讲,表级锁更适合以查询为主,只有少许按索引条件更新数据的应用,如web应用;行级锁更适合于大量按索引条件并发更新少许不一样数据,同时又有并发查询的应用,如一些在线事务处理系统。

mysql表级锁有两种模式:表共享读锁和表独占写锁。就是说对MyISAM表进行读操做时,他不会阻塞其余用户对同一张表的读请求,但会阻塞对同一表的写操做;而对MyISAM表的写操做,则会阻塞其余用户对同一张表的读和写操做。

MyISAM表的读和写是串行的,即在进行读操做时不能进行写操做,反之也是同样。但在必定条件下MyISAM表也支持查询和插入的操做的并发进行,其机制是经过一个系统变量来进行,当其值设置为0时,不容许并发插入;其值为1时,若是MyISAM表中没有空洞(即表中没有被删除的行),MyISAM容许在一个进程读表的同时,另外一个进程从表尾插入记录;当其值为2时,不管MyISAM表中有木有空洞,都容许在表尾并发插入记录。

MyISAM锁调度实现:当一个线程请求对MyISAM表中的读锁,同时另外一个线程也请求同一张表的写锁,此时写进程优先得到锁。可是大量的写操做会形成查询操做很难得到读锁,从而造程永久阻塞。能够经过指定参数low-priority-updates,使MyISAM默认引擎给与读请求优先的权利,设置为1(set low-priority-updates=1),使优先级下降。

InnoDB锁与MyISAM锁的最大不一样在于:一时支持事务。二是采用了行级锁。

事务四个属性(ACID):

一、原子性:事务是一个原子操做单位,其对数据的修改,要么所有执行,要么所有不执行。

二、一致性:在事务开始和完成时,数据都必须保持一致状态。

三、隔离性:数据库系统提供必定的隔离机制,保证事务在不受外部并发操做影响的独立环境执行。

四、持久性:事务完成后,他对于数据的修改是永久性的。

InnoDB有两种模式的行锁:

1)共享锁:容许一个事务去读一行,阻止其余事务得到相同数据集的排他锁。

select * from table_name where ... lock in share mode

2)排他锁:容许得到排它锁的事务更新数据,阻止其余事物取得相同数据集的共享读锁和排他写锁。

select * from table_name where ... for update

为了容许行锁和表锁共存,实现多粒度锁机制;同时还有两种内部使用的意向锁(都是表锁),分别为意向共享和意向排它锁。

InnoDB行锁是经过给索引加锁来实现的,即只有经过索引条件检索数据,InnoDB才使用行级锁,不然将使用表锁。

==================mysqlInnoDB锁表与锁行===============

因为InnoDB预设是Row-Level Lock,因此只有明确的指定主键,mysql才会执行row local(只锁住被选取的资料例),不然mysql将会执行table lock(锁表)。

例:明确指定主键 row lock

select * from table_name where id=3 for update

例:明确指定主键,若查无资源,无lock

select* from table_name where id=4 for update

例:无主键,table lock 

select * from table_name where name=“li” for update

例:主键不明确,table lock

select * from table_name where id <>5 for update

例:主键不明确,table lock 

select * from table_name where id like ‘3’ for update

MyISAM只支持表锁,InnoDB支持行级锁。

相关文章
相关标签/搜索