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 →

相关推荐
庞轩px6 小时前
第七篇:Spring扩展点——如何优雅地介入Bean的创建流程
java·后端·spring·bean·aware·扩展点
ltl7 小时前
Q/K/V 三件套:把 Bahdanau 抽象成一个公式
后端
千叶风行8 小时前
Text-to-SQL 技术设计与注意事项
前端·人工智能·后端
阿kun要赚马内9 小时前
后端数据操作组合:Pydantic与ORM
后端·python·orm·sqlalchemy
花米徐10 小时前
技术洞察精选 | 2026年4月28日 — 5月4日
后端·python·flask
阿维的博客日记11 小时前
Spring Cloud 为什么需要服务注册与发现中心这些东西?
后端·spring·spring cloud
笑而不语11 小时前
13|元数据过滤检索:UserContext 与按用户查知识
后端
用户0953675158311 小时前
Go:浮点数如何进行比较?
后端·go
Zeus_11 小时前
如何更好的创建skill
后端
千云11 小时前
AI Coding 落地探索日志 · 初篇 · 启程记
后端·ai编程