数据库什么时候会产生死锁?

网友解答: 不锁怕出事,锁了又怕锁死了!!!数据库由于数据存储速度快,数据稳定,结构化的特性,被广泛用作数据存储,并成为最重要,最常见的方式!数据库从20世纪50年代诞生伊始,就因为支持

网友解答:

不锁怕出事,锁了又怕锁死了!!!

数据库由于数据存储速度快,数据稳定,结构化的特性,被广泛用作数据存储,并成为最重要,最常见的方式!

数据库从20世纪50年代诞生伊始,就因为支持事务的特性得到大力的发展,最终各种数据库诸如oracle,Sybase,mysql等关系型数据库百花齐放,既然数据库是因为事务而生,那么事务的特性又是哪些呢?简而言之就是ACID(原子性,一致性,隔离性,持久性)!

而为了保持数据的一致性,数据库都有了一个操作叫做加锁!有表级锁,行级锁,页面锁!

死锁就是说两个线程在争同一个资源,然后互不相让,导致锁死的情况(比如两个人从两端走上独木桥,然后卡死在桥中间)!

回到问题本身,数据库在什么时候会产生死锁呢?

1,情况一:我中有你,你中有我!

事务一:两个操作update A;update B;

事务二:两个操作update B;update A;

线程一执行事务一到一半的时候,锁了A想要获得B的锁,与此同时事务二执行到了锁B,想要获得锁A的时候,因为互相都想要对方拥有的锁,而导致死锁!

2,情况二:吃着碗里的,看着锅里的!

A线程先查询了一条记录(使用了共享锁),与此同时B线程正要修改这条记录(使用了独占锁),然后A线程突然想修改这条记录了,怎么办呢?升级锁。。而B线程想要降级为共享锁,必须要等到A线程释放掉共享锁,这样就形成了死锁!

可以看到这个过程中是A占着共享锁想要升级,B占着独占锁想要降级,然后卡死!

3,牵一发而动全身!

一个表结构,必须要有适当的索引等优化手段,如果在执行事务的时候,没有加索引条件甚至没有任何条件,那么将执行全表扫描,如果是多个事务在操作,很容易就发生了阻塞和死锁!所以字段加索引非常重要!!

可以说数据库死锁必然会造成很严重的生产事故,所以要尽量避免死锁的发生,而如何避免呢?我会在后面的回答中逐一解答,敬请关注。。。

网友解答:

数据库是一个软件,是一个很多用户会一起使用的软件。

当多个用户同时的去操作数据库中数据的时候,在数据库中就会产生多个用户去存取同一条数据的情况。如果两个或多个以上的用户在执行的过程中,因争夺资源导致互相等待,并且将一直等待下去,这种情况叫做死锁。

产生死锁的条件

一条数据每次只能被一个用户使用。

一个用户请求资源阻塞时,对已经获得的资源保持不放

用户已经获得的资源,未使用前,别人不能抢走

几个用户形成首尾相接的循环等待资源

几个条件同时发生的时候,就会产生思索。

比如小明和小红都要做饭,做饭需要铲子和锅(加入铲子和锅各有一个)。

小明拿到了铲子,准备去找锅。

小红拿到了锅,准备去找铲子。

然后他/她俩就僵持住了,每个人都拿着手上的东西不放手,于是就一直僵持下去了。

数据库锁类型

排它锁(X锁):锁上之后,其他用户不能对其查询和修改。

共享锁(S锁):锁上之后,其他用户可以查询,但是不能修改。

标签: