我想知道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] 举报,一经查实,本站将立刻删除。