mirror of
				https://github.com/postgres/postgres.git
				synced 2025-11-03 09:13:20 +03:00 
			
		
		
		
	postgres_fdw: Inherit the local transaction's access/deferrable modes.
Previously, postgres_fdw always 1) opened a remote transaction in READ WRITE mode even when the local transaction was READ ONLY, causing a READ ONLY transaction using it that references a foreign table mapped to a remote view executing a volatile function to write in the remote side, and 2) opened the remote transaction in NOT DEFERRABLE mode even when the local transaction was DEFERRABLE, causing a SERIALIZABLE READ ONLY DEFERRABLE transaction using it to abort due to a serialization failure in the remote side. To avoid these, modify postgres_fdw to open a remote transaction in the same access/deferrable modes as the local transaction. This commit also modifies it to open a remote subtransaction in the same access mode as the local subtransaction. Although these issues exist since the introduction of postgres_fdw, there have been no reports from the field. So it seems fine to just fix them in master only. Author: Etsuro Fujita <etsuro.fujita@gmail.com> Reviewed-by: Ashutosh Bapat <ashutosh.bapat.oss@gmail.com> Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us> Discussion: https://postgr.es/m/CAPmGK16n_hcUUWuOdmeUS%2Bw4Q6dZvTEDHb%3DOP%3D5JBzo-M3QmpQ%40mail.gmail.com
This commit is contained in:
		@@ -1077,6 +1077,21 @@ postgres=# SELECT postgres_fdw_disconnect_all();
 | 
			
		||||
   <productname>PostgreSQL</productname> release might modify these rules.
 | 
			
		||||
  </para>
 | 
			
		||||
 | 
			
		||||
  <para>
 | 
			
		||||
   The remote transaction is opened in the same read/write mode as the local
 | 
			
		||||
   transaction: if the local transaction is <literal>READ ONLY</literal>,
 | 
			
		||||
   the remote transaction is opened in <literal>READ ONLY</literal> mode,
 | 
			
		||||
   otherwise it is opened in <literal>READ WRITE</literal> mode.
 | 
			
		||||
   (This rule is also applied to remote and local subtransactions.)
 | 
			
		||||
  </para>
 | 
			
		||||
 | 
			
		||||
  <para>
 | 
			
		||||
   The remote transaction is also opened in the same deferrable mode as the
 | 
			
		||||
   local transaction: if the local transaction is <literal>DEFERRABLE</literal>,
 | 
			
		||||
   the remote transaction is opened in <literal>DEFERRABLE</literal> mode,
 | 
			
		||||
   otherwise it is opened in <literal>NOT DEFERRABLE</literal> mode.
 | 
			
		||||
  </para>
 | 
			
		||||
 | 
			
		||||
  <para>
 | 
			
		||||
   Note that it is currently not supported by
 | 
			
		||||
   <filename>postgres_fdw</filename> to prepare the remote transaction for
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user