diff options
Diffstat (limited to 'src/backend/executor')
| -rw-r--r-- | src/backend/executor/nodeHash.c | 15 | 
1 files changed, 13 insertions, 2 deletions
| diff --git a/src/backend/executor/nodeHash.c b/src/backend/executor/nodeHash.c index e7e51d17172..ab766b84dc9 100644 --- a/src/backend/executor/nodeHash.c +++ b/src/backend/executor/nodeHash.c @@ -1574,8 +1574,19 @@ ExecHashRemoveNextSkewBucket(HashJoinTable hashtable)  		if (batchno == hashtable->curbatch)  		{  			/* Move the tuple to the main hash table */ -			hashTuple->next = hashtable->buckets[bucketno]; -			hashtable->buckets[bucketno] = hashTuple; +			HashJoinTuple copyTuple; + +			/* +			 * We must copy the tuple into the dense storage, else it will not +			 * be found by, eg, ExecHashIncreaseNumBatches. +			 */ +			copyTuple = (HashJoinTuple) dense_alloc(hashtable, tupleSize); +			memcpy(copyTuple, hashTuple, tupleSize); +			pfree(hashTuple); + +			copyTuple->next = hashtable->buckets[bucketno]; +			hashtable->buckets[bucketno] = copyTuple; +  			/* We have reduced skew space, but overall space doesn't change */  			hashtable->spaceUsedSkew -= tupleSize;  		} | 
