G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)

南大通用GBase 8s数据库(gbase database)解决事务并发问题,锁机制用于协调并发访问,防止多个事务同时操作数据导致的数据不一致。

锁粒度的操作

  • 行级锁:
    ALTER TABLE tab1 LOCK MODE (ROW);
    CREATE TABLE tab1 (...) LOCK MODE ROW;
  • 页面锁:
    ALTER TABLE tab1 LOCK MODE (PAGE);
    CREATE TABLE tab1 (...) LOCK MODE PAGE;
  • 表级锁:
    • 自动上锁:访问表内数据的时候,数据库会默认的为这张表上锁,比如说读取数据时可能上的是读锁,也可能不对表上锁,但是它会防止其他的事务对表的结构进行修改
    • 手动上锁:
      BEGIN WORK;
      LOCK TABLE tab1 IN EXCLUSIVE MODE;
      LOCK TABLE tab2 IN SHARE MODE;
      UNLOCK TABLE tab1;
  • 索引键锁:
    自动上锁,没办法主动使用,必须要有条件就是查询的表中必须要有索引,并且我们查询语句生成的执行计划必须要用到索引

锁粒度的选择

  • 库锁:独占式,数据库维护锁,适用于需要独占数据库的维护场景。
  • 表级锁:批量操作的并发控制手段,适用于批量更新和 DDL 操作等,可以有效避免并发冲突。
  • 页级锁:兼顾并发与管理的选择,适用于顺序访问等场景。
  • 行级锁:OLTP 系统高并发利器,适合 OLTP 系统,通过仅锁定修改行来提升并发能力。
  • 索引键锁:确保索引操作的完整性,Index-Key 锁是数据库在索引层面施加的锁,用于保护索引键值及其区间,防止并发事务插入或修改导致的幻读和一致性问题。

异常的锁等待情况

  • 活锁:事务长时间等待,锁总是被其他事务抢先获取
    解决:先来先服务(FIFO)排队机制。
  • 死锁:T1: LOCK R1 → 等待 R2;T2: LOCK R2 → 等待 R1
    产生条件:互斥、持有并等待、不可剥夺、循环等待。
    解决:预防和避免:破坏四个条件之一,资源分配图算法;检测与恢复:定期检测,选择牺牲者回滚。
相关推荐
xiezhr11 小时前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩1 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3502 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3502 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3502 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB3 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶3 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵3 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql