pageinspect
pageinspect模块提供函数让你从低层次观察数据库页面的内容,这对于调试目的很有用。所有这些函数只能被超级用户使用。
get_raw_page(relname text, fork text, blkno int) 返回 bytea
get_raw_page读取提及的关系中的指定块并且以一个bytea值的形式返回一个拷贝。这允许得到该块的一个单一的时间一致的拷贝。对于主数据分叉,*fork*应该是'main',对于空闲空间映射应该是'fsm',对于可见性映射应该是'vm',对于初始化分叉应该是'init'。
get_raw_page(relname text, blkno int) 返回 bytea
一个简写版的get_raw_page,用于读取主分叉。等效于get_raw_page(relname, 'main', blkno)
page_header(page bytea) 返回 record
page_header显示所有UDB-TX堆和索引页面的公共域。
用get_raw_page获得的一个页面映像应该作为参数传递。例如:
test=# SELECT * FROM page_header(get_raw_page('pg_class', 0));
lsn | checksum | flags | lower | upper | special | pagesize | version | prune_xid
-----------+----------+--------+-------+-------+---------+----------+---------+-----------
0/24A1B50 | 0 | 1 | 232 | 368 | 8192 | 8192 | 4 | 0
返回的列对应于PageHeaderData结构中的域。详见src/include/storage/bufpage.h。
checksum域是存放在页面中的校验和,如果页面被损坏它可能是不正确的。如果对这个实例没有启用数据校验和,则存储的这个值没有意义。
page_checksum(page bytea, blkno int4) returns smallint
page_checksum为页面计算校验和,就像它被放置在给定块上一样。
应该将get_raw_page得到的页面映像作为参数传入。例如:
test=# SELECT page_checksum(get_raw_page('pg_class', 0), 0);
page_checksum
---------------
13443
注意校验和取决于块号,因此应该将匹配的块号传入(除非在做调试)。
用这个函数计算的校验和可以拿来和函数page_header的结果域checksum进行比较。如果为这个实例启用了数据校验和,则两个值应该相等。
heap_page_items(page bytea) 返回 setof record
heap_page_items显示一个堆页面上所有的行指针。 对那些使用中的行指针,元组头部和元组原始数据也会被显示。 不管元组对于拷贝原始页面时的 MVCC 快照是否可见,它们都会被显示。
用get_raw_page获得的一个堆页面映像应该作为参数传递。例如:
test=# SELECT * FROM heap_page_items(get_raw_page('pg_class', 0));
返回的域的解释可见src/include/storage/itemid.h和src/include/access/htup_details.h。
tuple_data_split(rel_oid, t_data bytea, t_infomask integer, t_infomask2 integer, t_bits text [, do_detoast bool]) returns bytea[]
tuple_data_split以后端内部的相同方式将元组数据拆解成属性。
test=# SELECT tuple_data_split('pg_class'::regclass, t_data, t_infomask, t_infomask2, t_bits) FROM heap_page_items(get_raw_page('pg_class', 0));
应该用与heap_page_items的返回属性相同的参数来调用这个函数。
如果*do_detoast*是true,则根据需要将把属性解除TOAST。默认值为false。
heap_page_item_attrs(rel_oid, t_data bytea, [, do_detoast bool]) returns bytea[]
heap_page_item_attrs等效于 heap_page_items,不过它会把元组原始数据 返回为属性的数组,如果*do_detoast*为真( 默认为false),这些属性会被反 TOAST。
应该把用get_raw_page得到的一个堆页面映像 作为参数传入。例如:
test=# SELECT * FROM heap_page_item_attrs(get_raw_page('pg_class', 0), 'pg_class'::regclass);
fsm_page_contents(page bytea) returns text
fsm_page_contents展示一个FSM页面的内部节点结构。输出是一个多行字符串,每一行对应于页面中二叉树的每一个节点。只有非零节点才会被打印。所谓的“next”指针(指向页面中下一个要返回的槽)也会被打印。
更多有关FSM页面结构的信息请见src/backend/storage/freespace/README。