mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	per-column options for btree indexes. The planner's support for this is still pretty rudimentary; it does not yet know how to plan mergejoins with nondefault ordering options. The documentation is pretty rudimentary, too. I'll work on improving that stuff later. Note incompatible change from prior behavior: ORDER BY ... USING will now be rejected if the operator is not a less-than or greater-than member of some btree opclass. This prevents less-than-sane behavior if an operator that doesn't actually define a proper sort ordering is selected.
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			SQL
		
	
	
	
	
	
| --
 | |
| -- CIRCLE
 | |
| --
 | |
| 
 | |
| CREATE TABLE CIRCLE_TBL (f1 circle);
 | |
| 
 | |
| INSERT INTO CIRCLE_TBL VALUES ('<(5,1),3>');
 | |
| 
 | |
| INSERT INTO CIRCLE_TBL VALUES ('<(1,2),100>');
 | |
| 
 | |
| INSERT INTO CIRCLE_TBL VALUES ('1,3,5');
 | |
| 
 | |
| INSERT INTO CIRCLE_TBL VALUES ('((1,2),3)');
 | |
| 
 | |
| INSERT INTO CIRCLE_TBL VALUES ('<(100,200),10>');
 | |
| 
 | |
| INSERT INTO CIRCLE_TBL VALUES ('<(100,1),115>');
 | |
| 
 | |
| -- bad values
 | |
| 
 | |
| INSERT INTO CIRCLE_TBL VALUES ('<(-100,0),-100>');
 | |
| 
 | |
| INSERT INTO CIRCLE_TBL VALUES ('1abc,3,5');
 | |
| 
 | |
| INSERT INTO CIRCLE_TBL VALUES ('(3,(1,2),3)');
 | |
| 
 | |
| SELECT * FROM CIRCLE_TBL;
 | |
| 
 | |
| SELECT '' AS six, center(f1) AS center
 | |
|   FROM CIRCLE_TBL;
 | |
| 
 | |
| SELECT '' AS six, radius(f1) AS radius
 | |
|   FROM CIRCLE_TBL;
 | |
| 
 | |
| SELECT '' AS six, diameter(f1) AS diameter
 | |
|   FROM CIRCLE_TBL;
 | |
| 
 | |
| SELECT '' AS two, f1 FROM CIRCLE_TBL WHERE radius(f1) < 5;
 | |
| 
 | |
| SELECT '' AS four, f1 FROM CIRCLE_TBL WHERE diameter(f1) >= 10;
 | |
| 
 | |
| SELECT '' as five, c1.f1 AS one, c2.f1 AS two, (c1.f1 <-> c2.f1) AS distance
 | |
|   FROM CIRCLE_TBL c1, CIRCLE_TBL c2
 | |
|   WHERE (c1.f1 < c2.f1) AND ((c1.f1 <-> c2.f1) > 0)
 | |
|   ORDER BY distance, area(c1.f1), area(c2.f1);
 |