微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

枚举PostgreSQL类型的大小是多少?

我想知道Postgresql的枚举变量的大小是多少.例如,如果我创建一个包含100个不同项的枚举类型A,它的大小(以字节为单位)是多少?另外,当我创建一个包含A类属性的表时,该属性的大小是多少?

我检查了Postgresql文档,但我不明白最后一部分讨论枚举类型大小.

解决方法

枚举的大小是磁盘上的4个字节.期.这是因为枚举实现为整数或短路.每个整数值的标签保存在系统目录pg_enum中.您可以通过查询来查看它:

test=# select * from pg_enum;
 enumtypid | enumsortorder | enumlabel 
-----------+---------------+-----------
(0 rows)

test=# create type test_enum_t as enum('a','b','c');
CREATE TYPE
test=# select * from pg_enum;
 enumtypid | enumsortorder | enumlabel 
-----------+---------------+-----------
     68850 |             1 | a
     68850 |             2 | b
     68850 |             3 | c
(3 rows)

test=#

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐