b685dfa99f 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1838  from citusdata/fix_common_eq_class  
							
							... 
							
							
							
							The common attribute equivalence class should always include the input relations 
							
						 
						
							2017-11-30 17:14:04 +03:00  
				
					
						
							
							
								 
						
							
							
								a273711500 
								
							
								 
							
						 
						
							
							
								
								The common attribute equivalance class always includes the input relations  
							
							... 
							
							
							
							We added the ability to filter out the planner restriction information
for specific parts of the query. This might lead to situations where
the common restriction includes some other relations that we're searching
for. The reason is that while filtering for join restrictions, we add the
restriction as soon as we find the relation.
With this commit we make sure that the common attribute
equivalance class always includes the input relations. 
							
						 
						
							2017-11-30 16:00:26 +02:00  
				
					
						
							
							
								 
						
							
							
								8cb5734481 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1841  from citusdata/send_begin  
							
							... 
							
							
							
							Send begin in real-time executor when in a coordinated transaction 
							
						 
						
							2017-11-30 13:20:32 +01:00  
				
					
						
							
							
								 
						
							
							
								0d6a7f5884 
								
							
								 
							
						 
						
							
							
								
								Add real-time BEGIN regression tests  
							
							
							
						 
						
							2017-11-30 12:59:09 +01:00  
				
					
						
							
							
								 
						
							
							
								d6dd0b3a81 
								
							
								 
							
						 
						
							
							
								
								Send BEGIN in the real-time executor when in a transaction  
							
							
							
						 
						
							2017-11-30 12:59:09 +01:00  
				
					
						
							
							
								 
						
							
							
								581c8c02cc 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1840  from citusdata/remove_filter_checks  
							
							... 
							
							
							
							Remove filter checks on leaf queries 
							
						 
						
							2017-11-30 12:52:11 +01:00  
				
					
						
							
							
								 
						
							
							
								3a4d5f8182 
								
							
								 
							
						 
						
							
							
								
								Remove filter checks on leaf queries  
							
							
							
						 
						
							2017-11-30 12:25:14 +01:00  
				
					
						
							
							
								 
						
							
							
								7b8f13cf35 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1839  from citusdata/union_joins  
							
							... 
							
							
							
							Support UNION with joins in the subqueries 
							
						 
						
							2017-11-30 10:53:54 +01:00  
				
					
						
							
							
								 
						
							
							
								3f03cb6a6a 
								
							
								 
							
						 
						
							
							
								
								Support UNION with joins in the subqueries  
							
							
							
						 
						
							2017-11-30 10:37:56 +01:00  
				
					
						
							
							
								 
						
							
							
								906dadddb7 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1785  from citusdata/real_time_xact  
							
							... 
							
							
							
							Make real-time executor work in transactions (and fix pg_partman) 
							
						 
						
							2017-11-30 10:21:29 +03:00  
				
					
						
							
							
								 
						
							
							
								a9933deac6 
								
							
								 
							
						 
						
							
							
								
								Make real time executor work in transactions  
							
							
							
						 
						
							2017-11-30 09:59:32 +03:00  
				
					
						
							
							
								 
						
							
							
								73cadbecd6 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1836  from citusdata/fix_vacuum_analyze_propagation  
							
							... 
							
							
							
							Ensure VACUUM/ANALYZE stays local when unsupported or DDL prop disabled
cr: @pykello 
							
						 
						
							2017-11-29 16:36:46 -08:00  
				
					
						
							
							
								 
						
							
							
								6041f85b70 
								
									
								
							
								 
							
						 
						
							
							
								
								Add tests for non-propagated VACUUM/ANALYZE  
							
							
							
						 
						
							2017-11-29 16:06:50 -07:00  
				
					
						
							
							
								 
						
							
							
								0eacf6bd95 
								
									
								
							
								 
							
						 
						
							
							
								
								Refactor VacuumStmt checker to be single-return  
							
							... 
							
							
							
							Decided this would be safer for the future (defaults to unsupported). 
							
						 
						
							2017-11-29 16:06:50 -07:00  
				
					
						
							
							
								 
						
							
							
								b12e77ab0e 
								
									
								
							
								 
							
						 
						
							
							
								
								Ensure unsupported VACUUMs don't go to workers  
							
							... 
							
							
							
							Apparently these two blocks have been incorrect for nearly a year… 
							
						 
						
							2017-11-29 16:06:50 -07:00  
				
					
						
							
							
								 
						
							
							
								878d8192c4 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1835  from citusdata/zero_shard  
							
							... 
							
							
							
							Round-robin over worker nodes for 0-shard router queries 
							
						 
						
							2017-11-29 18:49:46 +01:00  
				
					
						
							
							
								 
						
							
							
								7ea718fd8d 
								
							
								 
							
						 
						
							
							
								
								Round-robin over worker nodes for 0-shard router queries  
							
							
							
						 
						
							2017-11-29 15:52:22 +01:00  
				
					
						
							
							
								 
						
							
							
								ae67fa0e52 
								
							
								 
							
						 
						
							
							
								
								Do not run multi_mx_modifications in parallel with multi_mx_transaction_recovery  
							
							
							
						 
						
							2017-11-29 15:35:21 +01:00  
				
					
						
							
							
								 
						
							
							
								198438978e 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1826  from citusdata/regression_data_ax  
							
							... 
							
							
							
							Regression data is reduced from 10K to 100 for 
events_table and users_table 
							
						 
						
							2017-11-28 15:16:03 +03:00  
				
					
						
							
							
								 
						
							
							
								b6eb0c2823 
								
							
								 
							
						 
						
							
							
								
								multi_subquery_behavioral_analytics.sql query fix by adding proper order by  
							
							
							
						 
						
							2017-11-28 14:15:46 +03:00  
				
					
						
							
							
								 
						
							
							
								1b06b2b306 
								
							
								 
							
						 
						
							
							
								
								The data used in regression tests is reduced  
							
							... 
							
							
							
							This commit reduces the size of the data in users_table.data
and events_table.data from 10K rows to 100 rows. 
							
						 
						
							2017-11-28 14:15:46 +03:00  
				
					
						
							
							
								 
						
							
							
								74b9bc409c 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1833  from citusdata/granular_subquery_pushdown  
							
							... 
							
							
							
							Refactor relation restriction equivalence checks to be more granular for subqueries 
							
						 
						
							2017-11-28 11:56:26 +03:00  
				
					
						
							
							
								 
						
							
							
								05fb0dd020 
								
							
								 
							
						 
						
							
							
								
								Add infrastructure for filtering restriction contexts based on the input query  
							
							... 
							
							
							
							In subquery pushdown, we first ensure that each relation is joined with at least
on another relation on the partition keys. That's fine given that the decision
is binary: pushdown the query at all or not.
With recursive planning, we'd want to check whether any specific part
of the query can be pushded down or not. Thus, we need the ability to
understand which part(s) of the subquery is safe to pushdown. This commit
adds the infrastructure for doing that. 
							
						 
						
							2017-11-28 09:58:21 +02:00  
				
					
						
							
							
								 
						
							
							
								26d9b58e9e 
								
							
								 
							
						 
						
							
							
								
								Make sure that ExtractRangeTableRelationWalker never misses RTE_RELATION  
							
							
							
						 
						
							2017-11-28 09:27:34 +02:00  
				
					
						
							
							
								 
						
							
							
								32def06ebd 
								
							
								 
							
						 
						
							
							
								
								Split assigning RTE identities and partitioning related query modifications  
							
							... 
							
							
							
							Note that we used to iterate over the RTEs once for performance reasons.
However, keeping an extra copy of original query seems more costly and
hard to maintain/explain. 
							
						 
						
							2017-11-28 09:27:34 +02:00  
				
					
						
							
							
								 
						
							
							
								271b9392e2 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1834  from citusdata/function_pushdown  
							
							... 
							
							
							
							Subqueries containing functions go through subquery pushdown 
							
						 
						
							2017-11-27 22:24:48 +01:00  
				
					
						
							
							
								 
						
							
							
								feffe86440 
								
							
								 
							
						 
						
							
							
								
								Subqueries containing functions go through subquery pushdown  
							
							
							
						 
						
							2017-11-27 22:13:02 +01:00  
				
					
						
							
							
								 
						
							
							
								8877a68a1f 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1827  from citusdata/allow_non_equi_joins  
							
							... 
							
							
							
							Enable non equi joins in subquery pushdown 
							
						 
						
							2017-11-23 17:51:02 +03:00  
				
					
						
							
							
								 
						
							
							
								48f96bf3e5 
								
							
								 
							
						 
						
							
							
								
								Enable non equi joins in subquery pushdown  
							
							... 
							
							
							
							Subquery pushdown planning is based on relation restriction
equivalnce. This brings us the opportuneatly to allow any
other joins as long as there is an already equi join between
the distributed tables.
We already allow that for joins with reference tables and
this commit allows that for joins among distributed tables. 
							
						 
						
							2017-11-23 16:13:46 +02:00  
				
					
						
							
							
								 
						
							
							
								ae2c86dbdd 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1823  from citusdata/regression_parallelization  
							
							... 
							
							
							
							Regression parallelization - PART 2 
							
						 
						
							2017-11-23 14:37:33 +03:00  
				
					
						
							
							
								 
						
							
							
								032b34ea52 
								
							
								 
							
						 
						
							
							
								
								some more parallelization  
							
							
							
						 
						
							2017-11-23 14:10:42 +03:00  
				
					
						
							
							
								 
						
							
							
								309ba9f0d6 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1825  from citusdata/register_custom_scans  
							
							... 
							
							
							
							Register custom scans 
							
						 
						
							2017-11-23 13:00:58 +03:00  
				
					
						
							
							
								 
						
							
							
								16421f089f 
								
							
								 
							
						 
						
							
							
								
								Register citus custom scan nodes  
							
							
							
						 
						
							2017-11-23 11:38:33 +02:00  
				
					
						
							
							
								 
						
							
							
								83c1143505 
								
							
								 
							
						 
						
							
							
								
								Refactor custom scan related codes  
							
							... 
							
							
							
							In this commit, we don't change any codes, only create a new
file and move the related functions and types there. 
							
						 
						
							2017-11-23 11:38:12 +02:00  
				
					
						
							
							
								 
						
							
							
								0799527d14 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1574  from citusdata/auto_2pc_recovery  
							
							... 
							
							
							
							Auto-recover 2PCs, enable 2PC by default 
							
						 
						
							2017-11-23 09:35:38 +01:00  
				
					
						
							
							
								 
						
							
							
								20a526d5c4 
								
							
								 
							
						 
						
							
							
								
								Fix memory leak in ListToHashSet  
							
							
							
						 
						
							2017-11-22 11:26:58 +01:00  
				
					
						
							
							
								 
						
							
							
								f4ceea5a3d 
								
							
								 
							
						 
						
							
							
								
								Enable 2PC by default  
							
							
							
						 
						
							2017-11-22 11:26:58 +01:00  
				
					
						
							
							
								 
						
							
							
								8486f76e15 
								
							
								 
							
						 
						
							
							
								
								Auto-recover 2PC transactions  
							
							
							
						 
						
							2017-11-22 11:26:58 +01:00  
				
					
						
							
							
								 
						
							
							
								64a5d5da22 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1814  from citusdata/rename_multiplan  
							
							... 
							
							
							
							Rename MultiPlan to DistributedPlan 
							
						 
						
							2017-11-22 09:57:55 +01:00  
				
					
						
							
							
								 
						
							
							
								6ba3f42d23 
								
							
								 
							
						 
						
							
							
								
								Rename MultiPlan to DistributedPlan  
							
							
							
						 
						
							2017-11-22 09:36:24 +01:00  
				
					
						
							
							
								 
						
							
							
								e3bd34727f 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1805  from citusdata/immutable_functions  
							
							... 
							
							
							
							Support immutable table functions as reference tables 
							
						 
						
							2017-11-21 14:48:30 +01:00  
				
					
						
							
							
								 
						
							
							
								0ad39b36fe 
								
							
								 
							
						 
						
							
							
								
								Treat immutable table functions and constant subqueries as reference tables  
							
							
							
						 
						
							2017-11-21 14:15:22 +01:00  
				
					
						
							
							
								 
						
							
							
								46c9922def 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1816  from citusdata/fix_reference_regression  
							
							... 
							
							
							
							Relax the checks for ensuring distribution columns in the target list 
							
						 
						
							2017-11-21 16:07:14 +03:00  
				
					
						
							
							
								 
						
							
							
								d558ebb923 
								
							
								 
							
						 
						
							
							
								
								Relax the checks on ensuring distribution columns for target entries  
							
							... 
							
							
							
							With this commit, we allow pushing down subqueries with only
reference tables where GROUP BY or DISTINCT clause or Window
functions include only columns from reference tables. 
							
						 
						
							2017-11-21 12:28:14 +02:00  
				
					
						
							
							
								 
						
							
							
								d063658d6d 
								
							
								 
							
						 
						
							
							
								
								Protect some initializations from being called during backend startup.  
							
							... 
							
							
							
							On EXEC_BACKEND builds these functions shouldn't be called at every
backend start. 
							
						 
						
							2017-11-20 15:29:51 -08:00  
				
					
						
							
							
								 
						
							
							
								d267e0f9fa 
								
							
								 
							
						 
						
							
							
								
								EXEC_BACKEND: don't put pointers to shared hashes into shared memory  
							
							... 
							
							
							
							Store pointers to shared hashes in process-local variables. Previously
pointers to shared hashes were put into shared memory. This causes
problems on EXEC_BACKEND because everybody calls execve and receives a
brand new address space; the shared hash will be in a different place
for every backend. (normally we call fork, which gives you a copy of the
address space, so these pointers remain constant) 
							
						 
						
							2017-11-20 15:29:51 -08:00  
				
					
						
							
							
								 
						
							
							
								30a2365d81 
								
							
								 
							
						 
						
							
							
								
								Rename CreateDirectory to CitusCreateDirectory  
							
							
							
						 
						
							2017-11-20 14:38:26 -08:00  
				
					
						
							
							
								 
						
							
							
								aa2ab023a2 
								
							
								 
							
						 
						
							
							
								
								Rename RemoveDirectory -> CitusRemoveDirectory  
							
							
							
						 
						
							2017-11-20 14:21:52 -08:00  
				
					
						
							
							
								 
						
							
							
								06f756b0a1 
								
							
								 
							
						 
						
							
							
								
								Rename DeleteFile -> CitusDeleteFile  
							
							
							
						 
						
							2017-11-20 13:30:11 -08:00  
				
					
						
							
							
								 
						
							
							
								4f3f30f939 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #1817  from citusdata/regression_parallelization  
							
							... 
							
							
							
							Regression parallelization - Part 1 
							
						 
						
							2017-11-20 19:14:48 +03:00