KingbaseES 表中隐藏字段说明
在KingbaseES中,当我们创建一个数据表时,数据库会隐式增加几个系统字段。这些字段由系统进行维护,用户一般不会感知它们的存在。
例如,以下语句创建了一个简单的表:
create table test(col number);
insert into test(col) values (1),(2),(3);
从定义上来看,表 test 中只有一个字段;但是当我们查询数据字典表 sys_attribute时,结果却不是如此:
test=# \d test
           数据表 "public.test"
 栏位 |  类型   | 校对规则 | 可空的 | 预设
------+---------+----------+--------+------
 col  | numeric 
test=# select attname, attnum, atttypid::regtype from sys_attribute where attrelid = 'test'::regclass;
 attname  | attnum | atttypid
----------+--------+----------
 tableoid |     -6 | oid
 cmax     |     -5 | cid
 xmax     |     -4 | xid
 cmin     |     -3 | cid
 xmin     |     -2 | xid
 ctid     |     -1 | tid
 col      |      1 | numeric
(7 行记录)
查询结果显示,表test一共包含7个字段。KingbaseES为我们增加了6个额外的系统字段,它们的attnum属性都是负数。
下面让我们分别看看这些系统字段的作用。
tableoid
tableoid 字段代表了数据所在表的对象 id(OID),也就是数据字典表 sys_class 中与该表信息相关的数据行。
test=# select oid, relname from sys_class where relname = 'test';
  oid  | relname
-------+---------
 51137 | test
(1 行记录)
test=# select tableoid, col from test ;
 tableoid | col
----------+-----
    51137 |   1
    51137 |   2
    51137 |   3
(3 行记录)
tableoid 的另一个用途就是在涉及分区表查询或者UNION操作时标识数据行所在的具体表(分区)。例如存在以下分区表:
test=# create table t_list(a int,b int)
test-# partition by list(a)
test-# (
test(#   partition p1 values (1,2,3,4,5),
test(#   partition p2 values (6,7,8,9,10)
test(# );
CREATE TABLE
test=# insert into t_list values(1,1);
INSERT 0 1
test=# insert into t_list values(7,1);
INSERT 0 1
test=# select tableoid::regclass,a from t_list;
 tableoid  | a
-----------+---
 t_list_p1 | 1
 t_list_p2 | 7
(2 行记录)
ctid
ctid 字段代表了数据行在表中的物理位置,也就是行标识(tuple identifier),由一对数值组成(块编号和行索引)。ctid 类似于 Oracle 中的伪列 ROWID。
需要注意的是,ctid的值有可能会改变(例如 VACUUM FULL);因此ctid不适合作为一个长期的行标识,应该使用主键作为行的逻辑标识。
test=# select ctid ,col from test;
 ctid  | col
-------+-----
 (0,1) |   1
 (0,2) |   2
 (0,3) |   3
(3 行记录)
test=# delete from test where col = 1;
DELETE 1
test=# select ctid ,col from test;
 ctid  | col
-------+-----
 (0,2) |   2
 (0,3) |   3
(2 行记录)
test=# vacuum full test;
VACUUM
test=# select ctid ,col from test;
 ctid  | col
-------+-----
 (0,1) |   2
 (0,2) |   3
(2 行记录)
xmin
xmin代表了该行版本(row version)的插入事务ID(XID)。行版本是数据行的具体状态,每次更新操作都会为相同的逻辑行创建一个新的行版本(多版本并发控制,MVCC)。
xmin 字段可以用于查看数据行的插入时间,需要事先打开track_commit_timestamp参数(前两行插入时参数未设置所以没有查询到时间)。
test=# insert into test(col) values (4),(5),(6);
INSERT 0 3
test=# select col,to_char(sys_xact_commit_timestamp(xmin) ,'YYYY-MM-DD HH24:MI:SS') AS insert_time from test;
 col |     insert_time
-----+---------------------
   2 |
   3 |
   4 | 2023-01-06 11:24:47
   5 | 2023-01-06 11:24:47
   6 | 2023-01-06 11:24:47
(5 行记录)
xmax
xmax 字段代表了删除该行的事务 ID,对于未删除的行版本显示为 0。非零的 xmax 通常意味着删除事务还没有提交,或者删除操作被回滚。
session 1:
test=# begin;
BEGIN
test=# update test set col=1 where col =4;
UPDATE 1
test=# select xmax,col from test;
 xmax | col
------+-----
    0 |   2
    0 |   3
    0 |   1
(3 行记录)
test=# delete from test where col =3;
DELETE 1
在事务未提交的情况下,在开一个新会话进行查询:
session 2
test=# select xmax,col from test;
 xmax  | col
-------+-----
     0 |   2
 42292 |   3
 42292 |   4
(3 行记录)
KingbaseES的update操作是一个先delete后insert的过程,所以在事务未提交的情况下,session 2能看到记录4被42292事务删除的信息。
session 1事务提交后,session 2 查询结果:
test=# select xmax,col from test;
 xmax | col
------+-----
    0 |   2
    0 |   1
(2 行记录)
cmin/cmax
代表元组变更的命令在插入事务中的命令标识(从0开始累加)。
test=# begin;
BEGIN
test=# insert into test values (3);
INSERT 0 1
test=# insert into test values (4);
INSERT 0 1
test=# insert into test values (5);
INSERT 0 1
test=# commit;
COMMIT
test=# insert into test values (6);
INSERT 0 1
test=# select cmin,cmax,col,xmin from test;
 cmin | cmax | col | xmin
------+------+-----+-------
    0 |    0 |   2 | 42290
    0 |    0 |   1 | 42292
    0 |    0 |   3 | 42293
    1 |    1 |   4 | 42293
    2 |    2 |   5 | 42293
    0 |    0 |   6 | 42294
KingbaseES 表中隐藏字段说明的更多相关文章
- 【HANA系列】SAP HANA SLT 在表中隐藏字段并传入HANA的方法
		公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA SLT在表中隐 ... 
- 【HANA系列】SAP HANA SLT在表中隐藏字段并传入HANA的方法
		公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA SLT在表中隐 ... 
- mysql向表中某字段后追加一段字符串:
		mysql向表中某字段后追加一段字符串:update table_name set field=CONCAT(field,'',str) mysql 向表中某字段前加字符串update table_n ... 
- 解决SQL server 2014 修改表中的字段,无法保存的问题。
		修改PROJECT表中的字段,保存时,弹出上面的窗体,无法保存. 解决方法为:[工具]->[选项]->[设计器]中,去掉“阻止保存要求重新创建表的更改”前的勾选. 
- mongoDB删除表中一个字段
		使用update命令 update命令 update命令格式: db.collection.update(criteria,objNew,upsert,multi) 参数说明: criteria:查询 ... 
- c++获取sqlite3数据库表中所有字段的方法
		常用方法: 1.使用sqlite3_get_table函数 2.获取sqlite创建表的sql语句字符串,然后进行解析获取到相应的字段 3.采用配置文件的方式,将所有字段名写入配置文件 方法1:使用s ... 
- syscolumns表中所有字段的意思
		--syscolumns表中所有字段的意思 name sysname --列名或过程参数的名称. id int --该列所属的表对象 ID,或与该参数关联的存储过程 ID. xtype tinyint ... 
- Oracle中使用游标转换数据表中指定字段内容格式(拼音转数字)
		应用场景:将数据表TB_USER中字段NNDP的内容中为[sannanyinv]转换为[3男1女] 主要脚本:一个游标脚本+分割字符串函数+拼音转数字脚本 操作步骤如下: 1.创建类型 create ... 
- 在oracle表中增加字段,并调整字段的顺序
		增加字段的语句很简单,以用户身份连接oracle服务: alter table tablename add(colname coltype); # 填上表名.字段名.字段类型 修改字段顺序前,查看表中 ... 
- SQL Server 复制表结构以及数据,去除表中重复字段
		--复制另一个数据库中的某张表的结构及数据--select * from Test.dbo.TestTable(查询表中所有数据) --into [表名] 插入当前数据库新表,如果没有该表就创建 se ... 
随机推荐
- Spring Boot图书管理系统项目实战-7.借阅图书
			导航: pre: 6.图书管理 next:8.续借图书 只挑重点的讲,具体的请看项目源码. 1.项目源码 需要源码的朋友,请捐赠任意金额后留下邮箱发送:) 2.页面设计 2.1 bookBorrow ... 
- QT - Day 5
			1 event事件 用途:用于事件的分发 也可以做拦截操作,不建议 bool event( QEvent * e); 返回值 如果是true 代表用户处理这个事件,不向下分发了 e->ty ... 
- 【Android逆向】反调试绕过(nop 绕过)
			1. 这是看雪上的一个题目,要求显示出 it is success https://www.kanxue.com/work-task_read-800648.htm 第三题 2. apk 安装到手机, ... 
- Singularity容器
			"""参考文档 https://apptainer.org/user-docs/master/build_a_container.html ""&qu ... 
- 如何创建自己的Spring Boot Starter并为其编写单元测试
			当我们想要封装一些自定义功能给别人使用的时候,创建Spring Boot Starter的形式是最好的实现方式.如果您还不会构建自己的Spring Boot Starter的话,本文将带你一起创建一个 ... 
- 在矩池云使用ChatGLM-6B & ChatGLM2-6B
			ChatGLM-6B 和 ChatGLM2-6B都是基于 General Language Model (GLM) 架构的对话语言模型,是清华大学 KEG 实验室和智谱 AI 公司于 2023 年共同 ... 
- 浅入 ABP 系列(7):对象映射
			目录 基础 DTO和实体 麻烦的映射 AutoMapper 集成 IObjectMapper/ObjectMapper 对象拓展 写博客的过程中,发现很多基础理论太薄弱,因此很多专业词汇可能会解释错误 ... 
- MVVM框架模式
			MVC框架模式 MVP框架模式 MVVM框架模式 MVVM模式即: 1.Model:数据层.网络数据操作,file文件操作,本地数据库操作: 2.View:视图层.布局加载,ui交互. 3.ViewM ... 
- ClickHouse学习笔记--ClickHouse的整体特性
			本文主要包含如下内容: ClickHouse适用场景 ClickHouse缺点 ClickHouse优点 ClickHouse表引擎-合并树 ClickHouse表引擎-合并树-稀疏索引 ClickH ... 
- Java面试必考题之线程的生命周期,结合源码,透彻讲解!
			写在开头 在前面的几篇博客里,我们学习了Java的多线程,包括线程的作用.创建方式.重要性等,那么今天我们就要正式踏入线程,去学习更加深层次的知识点了. 第一个需要学的就是线程的生命周期,也可以将之理 ... 
