mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Fix PHJ match bit initialization.
Hash join tuples reuse the HOT status bit to indicate match status
during hash join execution. Correct reuse requires clearing the bit in
all tuples. Serial hash join and parallel multi-batch hash join do so
upon inserting the tuple into the hashtable. Single batch parallel hash
join and batch 0 of unexpected multi-batch hash joins forgot to do this.
It hadn't come up before because hashtable tuple match bits are only
used for right and full outer joins and parallel ROJ and FOJ were
unsupported. 11c2d6fdf5 introduced support for parallel ROJ/FOJ but
neglected to ensure the match bits were reset.
Author: Melanie Plageman <melanieplageman@gmail.com>
Reported-by: Richard Guo <guofenglinux@gmail.com>
Discussion: https://postgr.es/m/flat/CAMbWs48Nde1Mv%3DBJv6_vXmRKHMuHZm2Q_g4F6Z3_pn%2B3EV6BGQ%40mail.gmail.com
			
			
This commit is contained in:
		| @@ -1724,6 +1724,7 @@ retry: | ||||
| 		/* Store the hash value in the HashJoinTuple header. */ | ||||
| 		hashTuple->hashvalue = hashvalue; | ||||
| 		memcpy(HJTUPLE_MINTUPLE(hashTuple), tuple, tuple->t_len); | ||||
| 		HeapTupleHeaderClearMatch(HJTUPLE_MINTUPLE(hashTuple)); | ||||
|  | ||||
| 		/* Push it onto the front of the bucket's list */ | ||||
| 		ExecParallelHashPushTuple(&hashtable->buckets.shared[bucketno], | ||||
|   | ||||
		Reference in New Issue
	
	Block a user