乐观锁,悲观锁,时间戳,

  1. 乐观锁
    1. 认为一个用户读数据的时候,别人不会去写自己所读的数据;
  2. 悲观锁
    1. 悲观锁和乐观锁刚好相反,觉得自己读数据库的时候,别人可能刚好在写自己刚读的数据, 其实就是持一种比较保守的态度;时间戳就是不加锁,通过时间戳来控制并 发出现的问题。 悲观锁就是在读取数据的时候,为了不让别人修改自己读取的数据,就会先 对自己读取的数据加锁,只有自己把数据读完了,才允许别人修改那部分数 据,或者反过来说,就是自己修改某条数据的时候,不允许别人读取该数据, 只有等自己的整个事务提交了,才释放自己加上的锁,才允许其他用户访问 那部分数据。
  3. 时间戳
    1. 时间戳就是在数据库表中单独加一列时间戳,比如“TimeStamp”, 每次读 出来的时候,把该字段也读出来,当写回去的时候,把该字段加1,提交之 前 ,跟数据库的该字段比较一次,如果比数据库的值大的话,就允许保存, 否则不允许保存,这种处理方法虽然不使用数据库系统提供的锁机制,但是 这种方法可以大大提高数据库处理的并发量,以上悲观锁所说的加“锁”,其 实分为几种锁,分别是: 排它锁(写锁) 和共享锁(读锁) 。
  4. 什么是行级锁
    1. 行级锁是一种排他锁,防止其他事务修改此行;在使用以下语句时, Oracle 会自动应 用行级锁: 1. INSERT、 UPDATE、 DELETE、 SELECT … FOR UPDATE [OF columns] [WAIT n | NOWAIT]; 2. SELECT … FOR UPDATE 语句允许用户一次锁定多条记录进行更新 3. 使用 COMMIT 或 ROLLBACK 语句释放锁。
  5. 什么是表级锁
    1. 表示对当前操作的整张表加锁,它实现简单,资源消耗较少,被大部分 MySQL 引擎支持。最常使用的 MYISAM 与 INNODB 都支持表级锁定。表 级锁定分为表共享读锁(共享锁)与表独占写锁(排他锁)。
  6. 什么是页级锁
    1. 页级锁是 MySQL 中锁定粒度介于行级锁和表级锁中间的一种锁。表级锁 速度快,但冲突多,行级冲突少,但速度慢。所以取了折衷的页级,一次 锁定相邻的一组记录。 BDB 支持页级锁
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值