mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Experiment with using EXPLAIN COSTS OFF in regression tests.
This is a simple test to see whether COSTS OFF will help much with getting EXPLAIN output that's sufficiently platform-independent for use in the regression tests. The planner does have some freedom of choice in these examples (plain via bitmap indexscan), so I'm not sure what will happen.
This commit is contained in:
		| @@ -112,25 +112,40 @@ SET enable_seqscan = OFF; | ||||
| SET enable_indexscan = ON; | ||||
| SET enable_bitmapscan = ON; | ||||
|  | ||||
| -- there's no easy way to check that these commands actually use | ||||
| -- the index, unfortunately.  (EXPLAIN would work, but its output | ||||
| -- changes too often for me to want to put an EXPLAIN in the test...) | ||||
| EXPLAIN (COSTS OFF) | ||||
| SELECT * FROM fast_emp4000 | ||||
|     WHERE home_base @ '(200,200),(2000,1000)'::box | ||||
|     ORDER BY (home_base[0])[0]; | ||||
| SELECT * FROM fast_emp4000 | ||||
|     WHERE home_base @ '(200,200),(2000,1000)'::box | ||||
|     ORDER BY (home_base[0])[0]; | ||||
|  | ||||
| EXPLAIN (COSTS OFF) | ||||
| SELECT count(*) FROM fast_emp4000 WHERE home_base && '(1000,1000,0,0)'::box; | ||||
| SELECT count(*) FROM fast_emp4000 WHERE home_base && '(1000,1000,0,0)'::box; | ||||
|  | ||||
| EXPLAIN (COSTS OFF) | ||||
| SELECT count(*) FROM fast_emp4000 WHERE home_base IS NULL; | ||||
| SELECT count(*) FROM fast_emp4000 WHERE home_base IS NULL; | ||||
|  | ||||
| EXPLAIN (COSTS OFF) | ||||
| SELECT * FROM polygon_tbl WHERE f1 ~ '((1,1),(2,2),(2,1))'::polygon | ||||
|     ORDER BY (poly_center(f1))[0]; | ||||
| SELECT * FROM polygon_tbl WHERE f1 ~ '((1,1),(2,2),(2,1))'::polygon | ||||
|     ORDER BY (poly_center(f1))[0]; | ||||
|  | ||||
| EXPLAIN (COSTS OFF) | ||||
| SELECT * FROM circle_tbl WHERE f1 && circle(point(1,-2), 1) | ||||
|     ORDER BY area(f1); | ||||
| SELECT * FROM circle_tbl WHERE f1 && circle(point(1,-2), 1) | ||||
|     ORDER BY area(f1); | ||||
|  | ||||
| EXPLAIN (COSTS OFF) | ||||
| SELECT count(*) FROM gpolygon_tbl WHERE f1 && '(1000,1000,0,0)'::polygon; | ||||
| SELECT count(*) FROM gpolygon_tbl WHERE f1 && '(1000,1000,0,0)'::polygon; | ||||
|  | ||||
| EXPLAIN (COSTS OFF) | ||||
| SELECT count(*) FROM gcircle_tbl WHERE f1 && '<(500,500),500>'::circle; | ||||
| SELECT count(*) FROM gcircle_tbl WHERE f1 && '<(500,500),500>'::circle; | ||||
|  | ||||
| RESET enable_seqscan; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user