mirror of
				https://github.com/pgadmin-org/pgadmin4.git
				synced 2025-02-25 18:55:31 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			109 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. _foreign_data_wrapper_dialog:
 | |
| 
 | |
| ************************************
 | |
| `Foreign Data Wrapper Dialog`:index:
 | |
| ************************************
 | |
| 
 | |
| Use the *Foreign Data Wrapper* dialog to create or modify a foreign data
 | |
| wrapper. A foreign data wrapper is an adapter between a Postgres database and
 | |
| data stored on another data source.
 | |
| 
 | |
| You must be a superuser to create a foreign data wrapper.
 | |
| 
 | |
| The *Foreign Data Wrapper* dialog organizes the development of a foreign data
 | |
| wrapper through the following dialog tabs: *General*, *Definition*, *Options*,
 | |
| and *Security*. The *SQL* tab displays the SQL code generated by dialog
 | |
| selections.
 | |
| 
 | |
| .. image:: images/foreign_data_wrapper_general.png
 | |
|     :alt: Foreign data wrapper dialog general tab
 | |
|     :align: center
 | |
| 
 | |
| Use the fields in the *General* tab to identify the foreign data wrapper:
 | |
| 
 | |
| * Use the *Name* field to add a descriptive name for the foreign data wrapper.
 | |
|   A foreign data wrapper name must be unique within the database. The name will
 | |
|   be displayed in the *pgAdmin* tree control.
 | |
| * Use the drop-down listbox next to *Owner* to select the name of the role that
 | |
|   will own the foreign data wrapper.
 | |
| * Store notes about the foreign data wrapper in the *Comment* field.
 | |
| 
 | |
| Click the *Definition* tab to continue.
 | |
| 
 | |
| .. image:: images/foreign_data_wrapper_definition.png
 | |
|     :alt: Foreign data wrapper dialog definition tab
 | |
|     :align: center
 | |
| 
 | |
| Use the fields in the *Definition* tab to set parameters:
 | |
| 
 | |
| * Select the name of the handler function from the drop-down listbox in the
 | |
|   *Handler* field. This is the name of an existing function that will be called
 | |
|   to retrieve the execution functions for foreign tables.
 | |
| * Select the name of the validator function from the drop-down listbox in the
 | |
|   *Validator* field. This is the name of an existing function that will be
 | |
|   called to check the generic options given to the foreign data wrapper, as
 | |
|   well as options for foreign servers, user mappings and foreign tables using
 | |
|   the foreign data wrapper.
 | |
| 
 | |
| Click the *Options* tab to continue.
 | |
| 
 | |
| .. image:: images/foreign_data_wrapper_options.png
 | |
|     :alt: Foreign data wrapper dialog options tab
 | |
|     :align: center
 | |
| 
 | |
| Use the fields in the *Options* tab to specify options:
 | |
| 
 | |
| * Click the the *Add* icon (+) button to add an option/value pair for the
 | |
|   foreign data wrapper. Supported option/value pairs will be specific to the
 | |
|   selected foreign data wrapper.
 | |
| * Specify the option name in the *Option* field and provide a corresponding
 | |
|   value in the *Value* field.
 | |
| 
 | |
| Click the *Add* icon (+) to specify each additional pair; to discard an option,
 | |
| click the trash icon to the left of the row and confirm deletion in the *Delete
 | |
| Row* popup.
 | |
| 
 | |
| Click the *Security* tab to continue.
 | |
| 
 | |
| .. image:: images/foreign_data_wrapper_security.png
 | |
|     :alt: Foreign data wrapper dialog security tab
 | |
|     :align: center
 | |
| 
 | |
| Use the *Security* tab to assign security privileges. Click the *Add* icon (+)
 | |
| to assign a set of privileges.
 | |
| 
 | |
| * Select the name of the role from the drop-down listbox in the *Grantee* field.
 | |
| * Click inside the *Privileges* field. Check the boxes to the left of one or
 | |
|   more privileges to grant the selected privileges to the specified user.
 | |
| * The current user, who is the default grantor for granting the privilege, is displayed in the *Grantor* field.
 | |
| 
 | |
| Click add to assign additional privileges; to discard a privilege, click the
 | |
| trash icon to the left of the row and confirm deletion in the *Delete Row*
 | |
| popup.
 | |
| 
 | |
| Click the *SQL* tab to continue.
 | |
| 
 | |
| Your entries in the *Foreign Data Wrapper* dialog generate a SQL command (see an
 | |
| example below). Use the *SQL* tab for review; revisit or switch tabs to make any
 | |
| changes to the SQL command.
 | |
| 
 | |
| Example
 | |
| *******
 | |
| 
 | |
| The following is an example of the sql command generated by user selections in
 | |
| the *Foreign Data Wrapper* dialog:
 | |
| 
 | |
| .. image:: images/foreign_data_wrapper_sql.png
 | |
|     :alt: Foreign data wrapper dialog sql tab
 | |
|     :align: center
 | |
| 
 | |
| The example creates a foreign data wrapper named *libpq_debug* that uses
 | |
| pre-existing validator and handler functions, *dblink_fdw_validator* and
 | |
| *libpg_fdw_handler*.  Selections on the *Options* tab set *debug* equal to
 | |
| *true*.  The foreign data wrapper is owned by *postgres*.
 | |
| 
 | |
| * Click the *Help* button (?) to access online help.
 | |
| * Click the *Save* button to save work.
 | |
| * Click the *Cancel* button to exit without saving work.
 | |
| * Click the *Reset* button to restore configuration parameters.
 |