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.
|