mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Using the just-added infrastructure, extend btree_gin to support cross-type operators in its other opclasses. All of the cross-type comparison operators supported by the core btree opclasses for these datatypes are now available for btree_gin indexes as well. 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
		
			
				
	
	
		
			95 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| set enable_seqscan=off;
 | |
| CREATE TABLE test_float8 (
 | |
| 	i float8
 | |
| );
 | |
| INSERT INTO test_float8 VALUES (-2),(-1),(0),(1),(2),(3);
 | |
| CREATE INDEX idx_float8 ON test_float8 USING gin (i);
 | |
| SELECT * FROM test_float8 WHERE i<1::float8 ORDER BY i;
 | |
|  i  
 | |
| ----
 | |
|  -2
 | |
|  -1
 | |
|   0
 | |
| (3 rows)
 | |
| 
 | |
| SELECT * FROM test_float8 WHERE i<=1::float8 ORDER BY i;
 | |
|  i  
 | |
| ----
 | |
|  -2
 | |
|  -1
 | |
|   0
 | |
|   1
 | |
| (4 rows)
 | |
| 
 | |
| SELECT * FROM test_float8 WHERE i=1::float8 ORDER BY i;
 | |
|  i 
 | |
| ---
 | |
|  1
 | |
| (1 row)
 | |
| 
 | |
| SELECT * FROM test_float8 WHERE i>=1::float8 ORDER BY i;
 | |
|  i 
 | |
| ---
 | |
|  1
 | |
|  2
 | |
|  3
 | |
| (3 rows)
 | |
| 
 | |
| SELECT * FROM test_float8 WHERE i>1::float8 ORDER BY i;
 | |
|  i 
 | |
| ---
 | |
|  2
 | |
|  3
 | |
| (2 rows)
 | |
| 
 | |
| explain (costs off)
 | |
| SELECT * FROM test_float8 WHERE i<1::float4 ORDER BY i;
 | |
|                  QUERY PLAN                  
 | |
| ---------------------------------------------
 | |
|  Sort
 | |
|    Sort Key: i
 | |
|    ->  Bitmap Heap Scan on test_float8
 | |
|          Recheck Cond: (i < '1'::real)
 | |
|          ->  Bitmap Index Scan on idx_float8
 | |
|                Index Cond: (i < '1'::real)
 | |
| (6 rows)
 | |
| 
 | |
| SELECT * FROM test_float8 WHERE i<1::float4 ORDER BY i;
 | |
|  i  
 | |
| ----
 | |
|  -2
 | |
|  -1
 | |
|   0
 | |
| (3 rows)
 | |
| 
 | |
| SELECT * FROM test_float8 WHERE i<=1::float4 ORDER BY i;
 | |
|  i  
 | |
| ----
 | |
|  -2
 | |
|  -1
 | |
|   0
 | |
|   1
 | |
| (4 rows)
 | |
| 
 | |
| SELECT * FROM test_float8 WHERE i=1::float4 ORDER BY i;
 | |
|  i 
 | |
| ---
 | |
|  1
 | |
| (1 row)
 | |
| 
 | |
| SELECT * FROM test_float8 WHERE i>=1::float4 ORDER BY i;
 | |
|  i 
 | |
| ---
 | |
|  1
 | |
|  2
 | |
|  3
 | |
| (3 rows)
 | |
| 
 | |
| SELECT * FROM test_float8 WHERE i>1::float4 ORDER BY i;
 | |
|  i 
 | |
| ---
 | |
|  2
 | |
|  3
 | |
| (2 rows)
 | |
| 
 |