数据库在并发时会出现很多问题,但有些时候会提高程序的运行效率,而有些时候则会产生非常严重的BUG。数据库为了解决因并发而产生的问题,于是底层采用数据库锁的的机制来解决并发问题,也就是类似Java中的同步锁。虽然不同数据库的锁机制在底层可能是不同的,但是它们的实现原理都是一样的。下面我们看一下数据库锁机制的底层实现原理。
锁的分类
按照锁定的对象不同可以分为表锁定和行锁定。它们的区别是前者是对整个表锁定,而后者是对表中的特定行进行锁定。从并发事物锁定的关系上来分,可以分为共享锁定和独占锁定。它们的区别是共享锁定会防止独占锁定,但允许其它的共享锁定。而独占锁定既防止其它的独占锁定又防止其它的共享锁定。
应用场景
按照上面介绍的锁的分类如果我们要对数据库进行数据更改时也就是UPDATE,那么数据库必须在进行更改的行上添加独占锁定,只有这样才能保证数据库的数据安全。除此之外还有INSERT、DELETE等操作都会隐式的添加行锁定。下面我们已Oracle数据库为例子,来重点介绍一下数据库的锁定。
Oracle锁