mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-22 14:32:25 +03:00 
			
		
		
		
	Extend the infrastructure in btree_gin.c to permit cross-type operators, and add the code to support them for the int2, int4, and int8 opclasses. (To keep this patch digestible, I left the other datatypes for a separate patch.) This improves the usability of btree_gin indexes by allowing them to support the same set of queries that a regular btree index does. Author: Tom Lane <tgl@sss.pgh.pa.us> Reviewed-by: Arseniy Mukhin <arseniy.mukhin.dev@gmail.com> Discussion: https://postgr.es/m/262624.1738460652@sss.pgh.pa.us
		
			
				
	
	
		
			34 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
			
		
		
	
	
			34 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
| set enable_seqscan=off;
 | |
| 
 | |
| CREATE TABLE test_int4 (
 | |
| 	i int4
 | |
| );
 | |
| 
 | |
| INSERT INTO test_int4 VALUES (-2),(-1),(0),(1),(2),(3);
 | |
| 
 | |
| CREATE INDEX idx_int4 ON test_int4 USING gin (i);
 | |
| 
 | |
| SELECT * FROM test_int4 WHERE i<1::int4 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i<=1::int4 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i=1::int4 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i>=1::int4 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i>1::int4 ORDER BY i;
 | |
| 
 | |
| explain (costs off)
 | |
| SELECT * FROM test_int4 WHERE i<1::int2 ORDER BY i;
 | |
| 
 | |
| SELECT * FROM test_int4 WHERE i<1::int2 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i<=1::int2 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i=1::int2 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i>=1::int2 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i>1::int2 ORDER BY i;
 | |
| 
 | |
| explain (costs off)
 | |
| SELECT * FROM test_int4 WHERE i<1::int8 ORDER BY i;
 | |
| 
 | |
| SELECT * FROM test_int4 WHERE i<1::int8 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i<=1::int8 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i=1::int8 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i>=1::int8 ORDER BY i;
 | |
| SELECT * FROM test_int4 WHERE i>1::int8 ORDER BY i;
 |