zoukankan      html  css  js  c++  java
  • 事务和锁--查看数据库中的锁

    数据库加锁是修改哪一条加锁,还是在页上加锁,还是在表上加锁,数据库来决定

    如果你更改的是两条记录,就在两条记录上加锁,如果你更改的是很多条,这个时候数据库一看一条一条加锁太麻烦,给整个页加锁更省事,或者给整个表加锁更加省事

    加锁的级别越大,数据库越省事,数据库越省事,并发性越差,修改一条记录如果给表加上独占锁,那么想查询别的记录都查询不了了

    加锁的对象越小,并发性越好

    加的锁对象越大,并发性越差

    刚开始就这几个锁

     

    1、开启事务修改学生的名字,给学号为0000000001的学生姓名加个‘_01’,事务不提交

     

    2、看到给Student表上的这1行加了独占锁
    ObjId:2105058535表示是Student这张表
    Type:RID表示是行标识
    Resource:1:567:0,表示是第1个数据文件的第576页的第1行
    Mode:X表示独占锁

    所以如下图查询学号为0000000001的学生,因为这行数据加了独占锁,所以一直查询不出来

    但是如下图查询学号不为0000000001的学生,就可以查询出来数据了,因为其他行并没有锁

    3、开启事务修改学生的名字,给学号对2取余等于0的这1批学生姓名加个_01,事务不提交

    4、看到给Student表加了独占锁
    ObjId:2105058535表示是Student这张表
    Type:TAB表示是表
    Mode:X表示独占锁

     如下图查询学号不为0000000001的学生或者查询任何数据,因为这个表加了独占锁,所以都不会查询出来

  • 相关阅读:
    前端开发小结(持续更新)
    UDP 通讯及内部分析(合集)
    困扰我三天的问题
    Clang Format Style Options (.clang-format 配置文件文档)
    关于共享库的那些事儿
    如何在VMWare的NAT模式下使用traceroute(解析vmnat的行为)
    Linux网络配置
    Ansible Ad-Hoc命令集
    Ansible基础使用
    Ansible部署及配置介绍
  • 原文地址:https://www.cnblogs.com/menglin2010/p/11847868.html
Copyright © 2011-2022 走看看