mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 01:29:19 +03:00 
			
		
		
		
	This function reads directly a page from a relation, relying on index_open() to open the index to read from. Unfortunately, this would crash when using partitioned indexes, as these can be opened with index_open() but they have no physical pages. Alexander has fixed the module, while I have written the test. Author: Alexander Lakhin, Michael Paquier Discussion: https://postgr.es/m/18246-f4d9ff7cb3af77e6@postgresql.org Backpatch-through: 12
		
			
				
	
	
		
			114 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
| CREATE TABLE test_hash (a int, b text);
 | |
| INSERT INTO test_hash VALUES (1, 'one');
 | |
| CREATE INDEX test_hash_a_idx ON test_hash USING hash (a);
 | |
| 
 | |
| CREATE TABLE test_hash_part (a int, b int) PARTITION BY RANGE (a);
 | |
| CREATE INDEX test_hash_part_idx ON test_hash_part USING hash(b);
 | |
| 
 | |
| \x
 | |
| 
 | |
| SELECT hash_page_type(get_raw_page('test_hash_a_idx', 0));
 | |
| SELECT hash_page_type(get_raw_page('test_hash_a_idx', 1));
 | |
| SELECT hash_page_type(get_raw_page('test_hash_a_idx', 2));
 | |
| SELECT hash_page_type(get_raw_page('test_hash_a_idx', 3));
 | |
| SELECT hash_page_type(get_raw_page('test_hash_a_idx', 4));
 | |
| SELECT hash_page_type(get_raw_page('test_hash_a_idx', 5));
 | |
| SELECT hash_page_type(get_raw_page('test_hash_a_idx', 6));
 | |
| 
 | |
| 
 | |
| SELECT * FROM hash_bitmap_info('test_hash_a_idx', -1);
 | |
| SELECT * FROM hash_bitmap_info('test_hash_a_idx', 0);
 | |
| SELECT * FROM hash_bitmap_info('test_hash_a_idx', 1);
 | |
| SELECT * FROM hash_bitmap_info('test_hash_a_idx', 2);
 | |
| SELECT * FROM hash_bitmap_info('test_hash_a_idx', 3);
 | |
| SELECT * FROM hash_bitmap_info('test_hash_a_idx', 4);
 | |
| SELECT * FROM hash_bitmap_info('test_hash_a_idx', 5);
 | |
| SELECT * FROM hash_bitmap_info('test_hash_a_idx', 6);
 | |
| SELECT * FROM hash_bitmap_info('test_hash_part_idx', 1); -- error
 | |
| 
 | |
| 
 | |
| SELECT magic, version, ntuples, bsize, bmsize, bmshift, maxbucket, highmask,
 | |
| lowmask, ovflpoint, firstfree, nmaps, procid, spares, mapp FROM
 | |
| hash_metapage_info(get_raw_page('test_hash_a_idx', 0));
 | |
| 
 | |
| SELECT magic, version, ntuples, bsize, bmsize, bmshift, maxbucket, highmask,
 | |
| lowmask, ovflpoint, firstfree, nmaps, procid, spares, mapp FROM
 | |
| hash_metapage_info(get_raw_page('test_hash_a_idx', 1));
 | |
| 
 | |
| SELECT magic, version, ntuples, bsize, bmsize, bmshift, maxbucket, highmask,
 | |
| lowmask, ovflpoint, firstfree, nmaps, procid, spares, mapp FROM
 | |
| hash_metapage_info(get_raw_page('test_hash_a_idx', 2));
 | |
| 
 | |
| SELECT magic, version, ntuples, bsize, bmsize, bmshift, maxbucket, highmask,
 | |
| lowmask, ovflpoint, firstfree, nmaps, procid, spares, mapp FROM
 | |
| hash_metapage_info(get_raw_page('test_hash_a_idx', 3));
 | |
| 
 | |
| SELECT magic, version, ntuples, bsize, bmsize, bmshift, maxbucket, highmask,
 | |
| lowmask, ovflpoint, firstfree, nmaps, procid, spares, mapp FROM
 | |
| hash_metapage_info(get_raw_page('test_hash_a_idx', 4));
 | |
| 
 | |
| SELECT magic, version, ntuples, bsize, bmsize, bmshift, maxbucket, highmask,
 | |
| lowmask, ovflpoint, firstfree, nmaps, procid, spares, mapp FROM
 | |
| hash_metapage_info(get_raw_page('test_hash_a_idx', 5));
 | |
| 
 | |
| SELECT live_items, dead_items, page_size, hasho_prevblkno, hasho_nextblkno,
 | |
| hasho_bucket, hasho_flag, hasho_page_id FROM
 | |
| hash_page_stats(get_raw_page('test_hash_a_idx', 0));
 | |
| 
 | |
| SELECT live_items, dead_items, page_size, hasho_prevblkno, hasho_nextblkno,
 | |
| hasho_bucket, hasho_flag, hasho_page_id FROM
 | |
| hash_page_stats(get_raw_page('test_hash_a_idx', 1));
 | |
| 
 | |
| SELECT live_items, dead_items, page_size, hasho_prevblkno, hasho_nextblkno,
 | |
| hasho_bucket, hasho_flag, hasho_page_id FROM
 | |
| hash_page_stats(get_raw_page('test_hash_a_idx', 2));
 | |
| 
 | |
| SELECT live_items, dead_items, page_size, hasho_prevblkno, hasho_nextblkno,
 | |
| hasho_bucket, hasho_flag, hasho_page_id FROM
 | |
| hash_page_stats(get_raw_page('test_hash_a_idx', 3));
 | |
| 
 | |
| SELECT live_items, dead_items, page_size, hasho_prevblkno, hasho_nextblkno,
 | |
| hasho_bucket, hasho_flag, hasho_page_id FROM
 | |
| hash_page_stats(get_raw_page('test_hash_a_idx', 4));
 | |
| 
 | |
| SELECT live_items, dead_items, page_size, hasho_prevblkno, hasho_nextblkno,
 | |
| hasho_bucket, hasho_flag, hasho_page_id FROM
 | |
| hash_page_stats(get_raw_page('test_hash_a_idx', 5));
 | |
| 
 | |
| SELECT * FROM hash_page_items(get_raw_page('test_hash_a_idx', 0));
 | |
| SELECT * FROM hash_page_items(get_raw_page('test_hash_a_idx', 1));
 | |
| SELECT * FROM hash_page_items(get_raw_page('test_hash_a_idx', 2));
 | |
| SELECT * FROM hash_page_items(get_raw_page('test_hash_a_idx', 3));
 | |
| SELECT * FROM hash_page_items(get_raw_page('test_hash_a_idx', 4));
 | |
| SELECT * FROM hash_page_items(get_raw_page('test_hash_a_idx', 5));
 | |
| 
 | |
| -- Failure with non-hash index
 | |
| CREATE INDEX test_hash_a_btree ON test_hash USING btree (a);
 | |
| SELECT hash_bitmap_info('test_hash_a_btree', 0);
 | |
| 
 | |
| -- Failure with various modes.
 | |
| -- Suppress the DETAIL message, to allow the tests to work across various
 | |
| -- page sizes and architectures.
 | |
| \set VERBOSITY terse
 | |
| -- invalid page size
 | |
| SELECT hash_metapage_info('aaa'::bytea);
 | |
| SELECT hash_page_items('bbb'::bytea);
 | |
| SELECT hash_page_stats('ccc'::bytea);
 | |
| SELECT hash_page_type('ddd'::bytea);
 | |
| -- invalid special area size
 | |
| SELECT hash_metapage_info(get_raw_page('test_hash', 0));
 | |
| SELECT hash_page_items(get_raw_page('test_hash', 0));
 | |
| SELECT hash_page_stats(get_raw_page('test_hash', 0));
 | |
| SELECT hash_page_type(get_raw_page('test_hash', 0));
 | |
| \set VERBOSITY default
 | |
| 
 | |
| -- Tests with all-zero pages.
 | |
| SHOW block_size \gset
 | |
| SELECT hash_metapage_info(decode(repeat('00', :block_size), 'hex'));
 | |
| SELECT hash_page_items(decode(repeat('00', :block_size), 'hex'));
 | |
| SELECT hash_page_stats(decode(repeat('00', :block_size), 'hex'));
 | |
| SELECT hash_page_type(decode(repeat('00', :block_size), 'hex'));
 | |
| 
 | |
| DROP TABLE test_hash;
 | |
| DROP TABLE test_hash_part;
 |