数据库锁表是什么意思?

 我来答
流蓉白0V
2018-12-22 · TA获得超过25.5万个赞
知道小有建树答主
回答量:116
采纳率:100%
帮助的人:4.1万
展开全部

1、数据库锁表的意思:因为在数据库里,同一个数据可能有多个人来读取或更改,为了防止我更改的时候别人也同时更改,这是一般要锁住表不让别人改。

2、举个简单例子:在更新数据库记录的过程中,我是不希望别人也来更新我的这些记录的,像库存,做出库的时候,原数量100,我出了20,我就需要把数量更新到80;

在更新的过程中,别人又做了30的出库,如果在我更新的时候,别人先把库存更新到70,然后我又更新80,那数量就错误了。所以我更新的时候,我就需要锁定这条记录。这是数据行锁,排他锁。

扩展资料:

数据库锁表的必要条件

1)互斥条件:指进程对所分配到的资源进行排它性使用,即在一段时间内某资源只由一个进程占用。如果此时还有其它进程请求资源,则请求者只能等待,直至占有资源的进程用毕释放。

2)请求和保持条件:指进程已经保持至少一个资源,但又提出了新的资源请求,而该资源已被其它进程占有,此时请求进程阻塞,但又对自己已获得的其它资源保持不放。

3)不剥夺条件:指进程已获得的资源,在未使用完之前,不能被剥夺,只能在使用完时由自己释放。

4)环路等待条件:指在发生死锁时,必然存在一个进程——资源的环形链,即进程集合{P0,P1,P2,···,Pn}中的P0正在等待一个P1占用的资源;P1正在等待P2占用的资源,……,Pn正在等待已被P0占用的资源。

阿豪呦1
2018-12-18 · TA获得超过9958个赞
知道答主
回答量:2
采纳率:0%
帮助的人:443
展开全部

数据库锁表:在数据库里,同一个数据可能有多个人来读取或更改,为了防止更改的时候别人也同时更改,这里一般要锁住表不让别人改。当然还有其它各种复杂情况。

数据库锁从类型上讲,有共享锁,意向锁,排他锁。从锁的粒度角度来说,可以分为为行、页键、键范围、索引、表或数据库获取锁。(锁粒度是被封锁目标的大小,封锁粒度小则并发性高,但开销大,封锁粒度大则并发性低但开销小)

可能的原因有:

(1)字段不加索引:在执行事务的时候,如果表中没有索引,会执行全表扫描,如果这时候有其他的事务过来,就会发生锁表!

(2)事务处理时间长:事务处理时间较长,当越来越多事务堆积的时候,会发生锁表!

(3)关联操作太多:涉及到很多张表的修改等,在并发量大的时候,会造成大量表数据被锁!

出现锁表的解决方法有:

(1)通过相关的sql语句可以查出是否被锁定,和被锁定的数据!

(2)为加锁进行时间限定,防止无限死锁!

(3)加索引,避免全表扫描!

(4)尽量顺序操作数据!

(5)根据引擎选择合理的锁粒度!

(6)事务中的处理时间尽量短!

生产中出现死锁等问题是比较严重的问题,因为通常死锁没有明显的错误日志,只有在发现错误的时候才能后知后觉的处理,所以,一定要尽力避免!

扩展资料:

封锁是指事务T在对某个数据对象(例如表、记录等)操作之前,先向系统发出请求,对其加锁。加锁后事务T就对该数据对象有了一定的控制,在事务T释放它的锁之前,其它的事务不能更新此数据对象。

锁表的基本类型有:

(1)排它锁(记为X锁)

排它锁又称为写锁。若事务T 对数据对象A 加上X 锁,则只允许T 读取和修改A , 其它任何事务都不能再对A 加任何类型的锁,直到T 释放A 上的锁。 

(2)共享锁(记为S锁)

共享锁又称为读锁。若事务T 对数据对象A 加上S 锁,则其它事务只能再对A 加S 锁,而不能加X 锁,直到T 释放A 上的S 锁。X锁和S锁都是加在某一个数据对象上的。

封锁单元有:

封锁的对象可以是逻辑单元,也可以是物理单元。

逻辑单元: 属性值、属性值集合、元组、关系、索引项、整个索引、整个数据库等;

物理单元:页(数据页或索引页)、块等。

封锁对象可以很大也可以很小,例如对整个数据库加锁、对某个属性值加锁。封锁对象的大小称为封锁的粒度。封锁的粒度越大,系统中能够被封锁的对象就越少,并发度也就越小,但系统开销也越小;封锁的粒度越小,并发度越高,但开销也就越大。

选择封锁粒度时必须同时考虑开销和并发度两个因素,进行权衡,以求得最优的效果。

一般原则为:

(1)需要处理大量元组的用户事务:以关系为封锁单元;

(2)需要处理多个关系的大量元组的用户事务:以数据库为封锁单位;

(3)只处理少量元组的用户事务:以元组为封锁单位

参考资料:封锁(数据库中的的封锁)_百度百科

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友4efe45b
2012-05-23 · TA获得超过441个赞
知道小有建树答主
回答量:266
采纳率:100%
帮助的人:298万
展开全部
锁表的概念稍微有点大,建议楼主找相关资料看一下数据库锁的相关知识。
举个简单例子:在更新数据库记录的过程中,我是不希望别人也来更新我的这些记录的,像库存,做出库的时候,原数量100,我出了20,我就需要把数量更新到80,在更新的过程中,别人又做了30的出库,如果在我更新的时候,别人先把库存更新到70,然后我又更新80,那数量就错误了。所以我更新的时候,我就需要锁定这条记录。这是数据行锁,排他锁。
这只是一个简单的例子,数据库的锁机制远比这个情景复杂。
锁从类型上讲,有共享锁,意向锁,排他锁。上面的例子是排它锁。
从锁的粒度角度来说,可以分为为行、页、键、键范围、索引、表或数据库获取锁。(锁粒度是被封锁目标的大小,封锁粒度小则并发性高,但开销大,封锁粒度大则并发性低但开销小)上面的例子中的锁粒度是行锁。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jiangjie_yahoo
2012-05-24 · TA获得超过151个赞
知道小有建树答主
回答量:235
采纳率:0%
帮助的人:51.5万
展开全部
因为在数据库里,同一个数据可能有多个人来读取或更改,为了防止我更改的时候别人也同时更改,这是一般要锁住表不让别人改。当然还有其它各种复杂情况。基本意思就是这样。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
云湖醉客
2012-05-24 · TA获得超过1983个赞
知道小有建树答主
回答量:820
采纳率:0%
帮助的人:308万
展开全部
就是数据库表被锁了呗
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式