KCP 模拟题练习 02 - 移动表空间锁表

【单选题】在 KingbaseES V8 中,把表从一个表空间移动到另一个表空间会锁表吗?

  • 不会

解题思路:

创建表空间 tbs01:

bash 复制代码
[root@kes ~]# mkdir /tbs01
[root@kes ~]# chown -R kingbase:kingbase /tbs01/
[root@kes ~]# chmod -R 700 /tbs01/

查看准备环境:

sql 复制代码
-- 创建表空间 tbs01
test=# create tablespace tbs01 location '/tbs01';
CREATE TABLESPACE

test=# \db
          表空间列表
    名称     | 拥有者 | 所在地 
-------------+--------+--------
 sys_default | system | 
 sys_global  | system | 
 sysaudit    | system | 
 tbs01       | system | /tbs01
(4 行记录)

test=# \dt
              关联列表
 架构模式 | 名称 |  类型  | 拥有者  
----------+------+--------+---------
 public   | t1   | 数据表 | lucifer
(1 行记录)

test=# select oid,relname from sys_class where relname='t1';
  oid  | relname 
-------+---------
 16513 | t1
(1 行记录)

另一个会话查看当前表是否存在锁:

sql 复制代码
test=# select * from sys_locks where relation=16513;
 locktype | database | relation | page | tuple | virtualxid | transactionid | classid | objid | objsubid | virtualtransaction | pid | mode | granted | fastpath 
----------+----------+----------+------+-------+------------+---------------+---------+-------+----------+--------------------+-----+------+---------+----------
(0 行记录)

模拟表移动表空间:

sql 复制代码
test=# begin;
BEGIN
test=# alter table t1 set tablespace tbs01;
ALTER TABLE

打开另一个会话查看表是否存在锁:

sql 复制代码
-- 此时表已存在一个锁
test=# select * from sys_locks where relation=16513;
 locktype | database | relation | page | tuple | virtualxid | transactionid | classid | objid | objsubid | virtualtransaction |  pid  |        mode         | granted | fastpath 
----------+----------+----------+------+-------+------------+---------------+---------+-------+----------+--------------------+-------+---------------------+---------+----------
 relation |    14509 |    16513 |      |       |            |               |         |       |          | 7/35962            | 61872 | AccessExclusiveLock | t       | f
(1 行记录)

原会话回滚移动表空间的事务:

sql 复制代码
test=# rollback;
ROLLBACK

在新的会话中再次查看锁是否存在:

sql 复制代码
test=# select * from sys_locks where relation=16513;
 locktype | database | relation | page | tuple | virtualxid | transactionid | classid | objid | objsubid | virtualtransaction | pid | mode | granted | fastpath 
----------+----------+----------+------+-------+------------+---------------+---------+-------+----------+--------------------+-----+------+---------+----------
(0 行记录)

此时,表的锁已经消失,所以,KingbaseES 数据库中表移动表空间会产生锁。


📚 推荐阅读:DBA 学习之路

如果这篇文章对你有帮助,推荐访问我的 Oracle DBA 系统学习站点,涵盖 100 天完整学习路线:

  • 🔧 Oracle 安装部署 · RMAN 备份恢复 · Data Pump 数据迁移
  • 🏗️ RAC 高可用 · DataGuard 容灾 · 多租户架构
  • 🔍 故障排查 · 升级迁移 · GoldenGate 数据同步

👉 立即访问 ora100.com →

相关推荐
JustHappy6 小时前
古法编程秘籍(二):什么是代码模块化?别背概念,把房间收拾明白就够了
前端·后端
小江的记录本6 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
IT_陈寒10 小时前
Python闭包里藏的这个坑,差点让我加班到凌晨
前端·人工智能·后端
IT_陈寒10 小时前
Java注解空指针?这个坑我踩得莫名其妙
前端·人工智能·后端
土狗TuGou10 小时前
SQL内功笔记 · 第8篇:事务的四大特性与隔离级别
数据库·笔记·后端·sql·mysql·oracle
ZengLiangYi10 小时前
React Query + REST API 最佳实践
javascript·后端·react.js
星浩AI10 小时前
项目实战:合同智能审批 · LangGraph + HITL 人机协同方案 [有源码]
后端·langchain·agent
JavaGuide10 小时前
Codex 接入第三方模型 DeepSeek、GLM、Kimi 教程:CC-Switch 和 Codex++ 两种方案对比
后端·ai编程
ZengLiangYi11 小时前
Fastify 加 Electron:把 Web 服务嵌进桌面应用
前端·javascript·后端
李白你好11 小时前
页面资产梳理 · 技术指纹识别 · Spring 端点探测
java·后端·spring