Gbase 8s 并发控制之粒度锁介绍

数据库级锁(Database level Locks)

        在我们通过CONNECT DATABASE或者CREATE DATABASE语句访问数据库时,系统都将自动在该数据库上加一个共享(S)锁,这样可以防止其他用户删除数据库或者在该数据库上加排它(X)锁。

表级锁(Table level Locks)

 表级锁就是指锁定的对象是一个表,可以通过如下语句显式的对表加锁和释放锁:

Begin work;

Lock table tab1 exclusive mode;

Lock table tab2 in share mode;

Unlock table tab1;

        在执行如下一些DDL语句时,GBASE 8S 会自动对表进行加锁,如alter fragment、alter index、alter table、create index(如果没有使用online模式)、drop index(如果没有使用online模式)、rename column、rename table。

        在整个表或者表中的大部分数据需要更新时,使用表级锁的效率高。

页级锁(page locks)

        GBASE 8s物理上把多行记录存放在数据页(page)上,页级锁的对象是一个数据页,当采用页级锁访问记录时,GBASE 8s会自动对访问的数据页进行加锁。当按物理顺序访问和更新更多条记录时,使用页级锁的效率较高。

可以通过如下方式指定页级锁模式:

Alter table tab1 lock mode(page);

Create table tab1 (...) lockmode page;

        Create table 时若不指定锁模式,则将采用onconfig 参数 def_table_lockmode 来指定表的锁模式。

行级锁(row locks)

        关系型数据库的数据是按行来管理的,所以行级锁很容易理解。在OLTP系统中行级锁的使用范围广泛,只需要锁定所访问的少数记录情况,使用行级锁的效率较高。

可以通过如下方式指定行级锁模式:

Alter table tab1 lock mode (row);

Create table tab1 (...) lock mode row;

        Create table 时若不指定锁模式,则将采用onconfig参数DEF_TABLE_LOCKMODE来指定表的锁模式。

索引锁(index locks)

        索引采用B+树的存储结构,所以对索引的锁管理就是管理索引的key值,数据库采用开、闭区域的方式进行索引的锁管理,示例如下:

Create table tab1 (c1 int,c2 int) lock mode row;

Create unique index idx_tab1 on tab1 (c1);

Insert into tab1 values(1,2);

Insert into tab1 values(2,2);

Insert into tab1 values(3,2);

        假设表中只有如上3行记录,当执行update tab1 set c1 >= 3;语句时,GBASE 8s 将对索引key值为3的记录进行闭合区间加锁,意味着此时不能新增key值大于3的记录。若此时执行insert into tab1 values(4,2),则会提示index锁冲突错误。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

八珍豆腐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值