mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Replace "amgetmulti" AM functions with "amgetbitmap", in which the whole
indexscan always occurs in one call, and the results are returned in a TIDBitmap instead of a limited-size array of TIDs. This should improve speed a little by reducing AM entry/exit overhead, and it is necessary infrastructure if we are ever to support bitmap indexes. In an only slightly related change, add support for TIDBitmaps to preserve (somewhat lossily) the knowledge that particular TIDs reported by an index need to have their quals rechecked when the heap is visited. This facility is not really used yet; we'll need to extend the forced-recheck feature to plain indexscans before it's useful, and that hasn't been coded yet. The intent is to use it to clean up 8.3's horrid @@@ kluge for text search with weighted queries. There might be other uses in future, but that one alone is sufficient reason. Heikki Linnakangas, with some adjustments by me.
This commit is contained in:
		| @@ -143,7 +143,7 @@ RESET enable_bitmapscan; | ||||
|  | ||||
| SET enable_seqscan = OFF; | ||||
| SET enable_indexscan = ON; | ||||
| SET enable_bitmapscan = ON; | ||||
| SET enable_bitmapscan = OFF; | ||||
|  | ||||
| CREATE INDEX intarrayidx ON array_index_op_test USING gin (i); | ||||
|  | ||||
| @@ -167,6 +167,18 @@ SELECT * FROM array_index_op_test WHERE t && '{AAAAAAAA72908,AAAAAAAAAA646}' ORD | ||||
| SELECT * FROM array_index_op_test WHERE t <@ '{AAAAAAAA72908,AAAAAAAAAAAAAAAAAAA17075,AA88409,AAAAAAAAAAAAAAAAAA36842,AAAAAAA48038,AAAAAAAAAAAAAA10611}' ORDER BY seqno; | ||||
| SELECT * FROM array_index_op_test WHERE t = '{AAAAAAAAAA646,A87088}' ORDER BY seqno; | ||||
|  | ||||
| -- Repeat some of the above tests but exercising bitmapscans instead | ||||
| SET enable_indexscan = OFF; | ||||
| SET enable_bitmapscan = ON; | ||||
|  | ||||
| SELECT * FROM array_index_op_test WHERE i @> '{32}' ORDER BY seqno; | ||||
| SELECT * FROM array_index_op_test WHERE i && '{32}' ORDER BY seqno; | ||||
| SELECT * FROM array_index_op_test WHERE i @> '{17}' ORDER BY seqno; | ||||
| SELECT * FROM array_index_op_test WHERE i && '{17}' ORDER BY seqno; | ||||
| SELECT * FROM array_index_op_test WHERE i @> '{32,17}' ORDER BY seqno; | ||||
| SELECT * FROM array_index_op_test WHERE i && '{32,17}' ORDER BY seqno; | ||||
| SELECT * FROM array_index_op_test WHERE i <@ '{38,34,32,89}' ORDER BY seqno; | ||||
| SELECT * FROM array_index_op_test WHERE i = '{47,77}' ORDER BY seqno; | ||||
|  | ||||
| RESET enable_seqscan; | ||||
| RESET enable_indexscan; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user