文档章节

数据库表锁和行锁

竹叶青出于蓝
 竹叶青出于蓝
发布于 2017/04/06 17:08
字数 2165
阅读 20
收藏 1
点赞 0
评论 0

页级锁:引擎BDB。

表级锁:引擎MyISAM,锁住整个表,可以同时读,写不行。

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

表级,直接锁定整张表,在锁定期间,其他进程无法对该表进行写操作。如果你是写锁,则其他进程无法进行读操作。

行级,仅对指定的记录进行加锁,这样其他进程还是可以对同一张表中其他的记录进行操作。

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

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

 

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

如果在表上没有锁,在它上面放一个写锁。否则,把锁定请求放在写锁定队列中。

对read,mysql使用的锁定方法原理如下:

如果在表上没有写锁定,把一个读锁定放到它上面。否则,把锁清秋放在读锁定队列中。

 

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

行锁定的优点:

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

2、回滚时只有少量的更改。

3、可以长时间锁定单一的行

行级锁定的缺点:

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

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

3、如果在大部分数据上经常进行GroupBY操作或者必须经常扫描整个表,比其他锁定明显慢很多。

4、用高级别锁定,通过支持不同的类型锁定,也可以很容易调节应用程序,因为其锁成本小于行级锁定。

在以下情况,表锁定优先页级或行级锁定:

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

2、对严格的关键字进行读取和更新,可以用单一的读取关键词来提取一行。

3、select结合并行的insert语句,并且只有很少的update或delete语句。

4、在整个表上有许多扫描或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;

行级锁的优点:

1、在很多线程请求不同记录时减少冲突锁。

2、事务回滚时减少改变数据。

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

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

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

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):

1、原子性:事务是一个原子操作单位,其对数据的修改,要么全部执行,要么全部不执行。

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

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

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

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支持行级锁。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

本文转载自:

共有 人打赏支持
竹叶青出于蓝
粉丝 0
博文 30
码字总数 3947
作品 0
昌平
程序员
数据提交一直在挂起状态(IE显示请求挂起)

最近忽然发现项目提交的时候一直在提交状态,不能提交成功,客户反馈提交了4个多小时还在提交中,应用也没发现什么明显错误,前台显示如下(IE下才会有这种提示,其他的浏览器没错误): 刚发...

sprouting ⋅ 01/13 ⋅ 0

MySQL数据库 锁机制简介

MySQL数据库 锁机制简介 数据库锁定机制简单来说就是数据库为了保证数据的一致性而使各种共享资源在被并发访问访问变得有序所设计的一种规则。对于任何一种数据库来说都需要有相应的锁定机制...

LYQ1990 ⋅ 2016/04/29 ⋅ 0

Oracle的TX锁(行级锁、事务锁)

问题:如何使用事务? 回答:一共有三步。 1、先开启事务。 •在Oracle中,事务是在上一次事务结束以后,数据“第一次”被修改时自动开启。 •在java中,设置连接为手动提交模式开始。代码:...

swearyd457 ⋅ 2013/10/10 ⋅ 0

mysql锁知识小了解

一、概述 mysql的锁分为表锁和行锁两种,其中myisam引擎用的是表锁, innoDB默认的使用是行锁, 其他情况是表锁。 两种锁的优缺点: 表级锁:加锁速度快,开销小。不会出现死锁的情况,粒度大...

GuoYJ ⋅ 2015/09/13 ⋅ 0

oracle的锁机制

oracle数据库是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据...

柳哥 ⋅ 2014/06/29 ⋅ 0

『浅入浅出』MySQL 和 InnoDB

作为一名开发人员,在日常的工作中会难以避免地接触到数据库,无论是基于文件的 sqlite 还是工程上使用非常广泛的 MySQL、PostgreSQL,但是一直以来也没有对数据库有一个非常清晰并且成体系的...

xrzs ⋅ 2012/08/30 ⋅ 0

数据库锁总结

一直想写一篇关于数据库锁的相关总结文章,因为平时看数据库相关的博文的时候,会时不时看到某个数据库锁,一直没弄清楚各种锁的关系,下面就大概总结一下,希望园友提出问题。   数据库锁...

17099933344 ⋅ 2017/08/03 ⋅ 0

MySQL数据库的锁机制

在并发访问情况下,很有可能出现不可重复读等等读现象。为了更好的应对高并发,封锁、时间戳、乐观并发控制(乐观锁)、悲观并发控制(悲观锁)都是并发控制采用的主要技术方式。 锁分类 ①、按操...

Javahih ⋅ 01/02 ⋅ 0

数据库事务浅析

ACID 一个数据库事务通常包含了一个序列的对数据库的读/写操作。它的存在包含有以下两个目的: 为数据库操作序列提供了一个从失败中恢复到正常状态的方法,同时提供了数据库即使在异常状态下...

德彪 ⋅ 2017/12/01 ⋅ 0

InnoDB 存储引擎的主要知识点介绍

本文转载自:Draveness,略有修改 原文链接:『浅入浅出』MySQL 和 InnoDB · 面向信仰编程 作为一名开发人员,在日常的工作中会难以避免地接触到数据库,无论是基于文件的 sqlite 还是工程上...

踏雪无痕SS ⋅ 06/13 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

如何使用serverchan微信推送告警

之前实现推送告警信息到微信的方法有如下几种: 1、通过企业公众号实现----收费: 2、通过QQ邮箱,在微信平台上开启收到邮件进行提醒; 3、第三方告警平台API,一般也是收费的; 不过最近看文...

问题终结者 ⋅ 26分钟前 ⋅ 0

TCP的RPC

RPC就是远程方法调用(Remote Process Call ),包含了客户端和服务端,涉及了对象的序列化传输。 1.服务端启动,注册远程调用的类2.客户端发送请求信息包含类、方法、参数的一些信息、序列化传...

Cobbage ⋅ 47分钟前 ⋅ 0

IOS-UI UI初步代码布局添加事件

ISO开发界面,UI是必须学习的一部分,其实很早之前想学来了,一直没有沉下心来学习。看到IOS的代码风格和布局就别扭的不行,跟java代码和android布局比较显得不是那么方便,所以一直到现在。...

京一 ⋅ 57分钟前 ⋅ 0

浅谈OpenDaylight的二次开发

OpenDaylight作为一款开源SDN网络控制器,依托于强大的社区支持以及功能特性,成为了目前主流的SDN网络控制器开发平台。在比较稳定的OpenDaylight Helium版本中,已经为开发者提供了大量的网...

wangxuwei ⋅ 今天 ⋅ 0

API 开发中可选择传递 token 接口遇到的一个坑

在做 API 开发时,不可避免会涉及到登录验证,我使用的是jwt-auth 在登录中会经常遇到一个token过期的问题,在config/jwt.php默认设置中,这个过期时间是一个小时,不过为了安全也可以设置更...

等月人 ⋅ 今天 ⋅ 0

Java NIO之文件处理

程序要操作本地操作系统的一个文件,可以分为以下三个部分: 对文件位置的操作 对文件的操作 对文件内容的操作 其中,对文件内容的操作在 Java NIO之Channel 中已经有了介绍,通过FileChann...

士别三日 ⋅ 今天 ⋅ 0

Maven的pom.xml配置文件详解

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.......

小海bug ⋅ 今天 ⋅ 0

解决httpclient超时设置不生效的问题

最近公司有项目需要通过http调用第三方服务,且第三方服务偶有超时,故需要设置一定的超时时间防止不响应的情况出现。 初始设置如下: [java] view plain copy //超时设置 RequestConfig re...

Mr_Tea伯奕 ⋅ 今天 ⋅ 0

过滤器Filter和拦截器HandlerInterceptor

过滤器 依赖于servlet容器。在实现上基于函数回调,可以对几乎所有请求进行过滤,但是缺点是一个过滤器实例只能在容器初始化时调用一次。使用过滤器的目的是用来做一些过滤操作,获取我们想要...

hutaishi ⋅ 今天 ⋅ 0

Redis入门详解(转)

Redis入门详解 Redis简介 Redis安装 Redis配置 Redis数据类型 Redis功能 持久化 主从复制 事务支持 发布订阅 管道 虚拟内存 Redis性能 Redis部署 Redis应用场景 Redis总结 Redis简介: Redi...

xiaoyaoyoufang ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部