2016-05-27 16:13:36 +00:00
|
|
|
.. _function_dialog:
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2018-06-15 08:14:12 +00:00
|
|
|
************************
|
|
|
|
`Function Dialog`:index:
|
|
|
|
************************
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
Use the *Function* dialog to define a function. If you drop and then recreate
|
|
|
|
a function, the new function is not the same entity as the old; you must drop
|
|
|
|
existing rules, views, triggers, etc. that refer to the old function.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
The *Function* dialog organizes the development of a function through the
|
2019-08-02 09:25:21 +00:00
|
|
|
following dialog tabs: *General*, *Definition*, *Code*, *Options*,
|
2019-03-08 15:29:05 +00:00
|
|
|
*Parameters*, and *Security*. The *SQL* tab displays the SQL code generated by
|
|
|
|
dialog selections.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2016-05-20 20:39:21 +00:00
|
|
|
.. image:: images/function_general.png
|
2018-01-11 16:58:30 +00:00
|
|
|
:alt: Function dialog general tab
|
2019-03-08 15:29:05 +00:00
|
|
|
:align: center
|
2016-05-13 13:43:57 +00:00
|
|
|
|
|
|
|
Use the fields in the *General* tab to identify a function:
|
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
* Use the *Name* field to add a descriptive name for the function. 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 function.
|
|
|
|
* Use the drop-down listbox next to *Schema* to select the schema in which the
|
|
|
|
function will be created.
|
2016-05-24 12:47:35 +00:00
|
|
|
* Store notes about the function in the *Comment* field.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
|
|
|
Click the *Definition* tab to continue.
|
|
|
|
|
2016-05-20 20:39:21 +00:00
|
|
|
.. image:: images/function_definition.png
|
2018-01-11 16:58:30 +00:00
|
|
|
:alt: Function dialog definition tab
|
2019-03-08 15:29:05 +00:00
|
|
|
:align: center
|
2016-05-13 13:43:57 +00:00
|
|
|
|
|
|
|
Use the fields in the *Definition* tab to define the function:
|
|
|
|
|
2023-11-28 10:24:44 +00:00
|
|
|
* Move the *Custom return type?* switch to provide a user defined return type.
|
2019-03-08 15:29:05 +00:00
|
|
|
* Use the drop-down listbox next to *Return type* to select the data type
|
2023-11-28 10:24:44 +00:00
|
|
|
returned by the function, if any. If *Custom return type?* is enabled this field
|
|
|
|
will change to an input text field.
|
2019-03-08 15:29:05 +00:00
|
|
|
* Use the drop-down listbox next to *Language* to select the implementation
|
|
|
|
language. The default is *sql*.
|
2019-08-02 09:25:21 +00:00
|
|
|
* Use the fields in the *Arguments* to define an argument. Click the *Add*
|
|
|
|
icon (+) to set parameters and values for the argument:
|
|
|
|
|
|
|
|
* Use the drop-down listbox in the *Data type* field to select a data type.
|
|
|
|
* Use the drop-down listbox in the *Mode* field to select a mode. Select *IN*
|
|
|
|
for an input parameter; select *OUT* for an output parameter; select *INOUT*
|
|
|
|
for both an input and an output parameter; or, select *VARIADIC* to specify a
|
|
|
|
VARIADIC parameter.
|
|
|
|
* Provide a name for the argument in the *Argument Name* field.
|
|
|
|
* Specify a default value for the argument in the *Default Value* field.
|
|
|
|
|
|
|
|
Click the *Add* icon (+) to define another argument; to discard an argument,
|
|
|
|
click the trash icon to the left of the row and confirm deletion in the *Delete
|
|
|
|
Row* popup.
|
|
|
|
|
|
|
|
Click the *Code* tab to continue.
|
|
|
|
|
|
|
|
.. image:: images/function_code.png
|
|
|
|
:alt: Function dialog code tab
|
|
|
|
:align: center
|
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
* Use the *Code* field to write the code that will execute when the function
|
|
|
|
is called.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
|
|
|
Click the *Options* tab to continue.
|
|
|
|
|
2016-05-20 20:39:21 +00:00
|
|
|
.. image:: images/function_options.png
|
2018-01-11 16:58:30 +00:00
|
|
|
:alt: Function dialog options tab
|
2019-03-08 15:29:05 +00:00
|
|
|
:align: center
|
|
|
|
|
|
|
|
Use the fields in the *Options* tab to describe or modify the action of the
|
|
|
|
function:
|
|
|
|
|
|
|
|
* Use the drop-down listbox next to *Volatility* to select one of the following.
|
|
|
|
*VOLATILE* is the default value.
|
|
|
|
|
|
|
|
* *VOLATILE* indicates that the function value can change even within a
|
|
|
|
single table scan, so no optimizations can be made.
|
|
|
|
* *STABLE* indicates that the function cannot modify the database, and that
|
|
|
|
within a single table scan it will consistently return the same result for
|
|
|
|
the same argument values.
|
|
|
|
* *IMMUTABLE* indicates that the function cannot modify the database and
|
|
|
|
always returns the same result when given the same argument values.
|
|
|
|
|
|
|
|
* Move the *Returns a Set?* switch to indicate if the function returns a set
|
|
|
|
that includes multiple rows. The default is *No*.
|
|
|
|
* Move the *Strict?* switch to indicate if the function always returns NULL
|
|
|
|
whenever any of its arguments are NULL. If *Yes*, the function is not executed
|
|
|
|
when there are NULL arguments; instead a NULL result is assumed
|
|
|
|
automatically. The default is *No*.
|
|
|
|
* Move the *Security of definer?* switch to specify that the function is to be
|
|
|
|
executed with the privileges of the user that created it. The default is *No*.
|
|
|
|
* Move the *Window?* switch to indicate that the function is a window function
|
|
|
|
rather than a plain function. The default is *No*. This is currently only
|
|
|
|
useful for functions written in C. The WINDOW attribute cannot be changed when
|
|
|
|
replacing an existing function definition. For more information about the
|
|
|
|
CREATE FUNCTION command, see the PostgreSQL core documentation available at:
|
|
|
|
|
2019-03-12 14:24:46 +00:00
|
|
|
https://www.postgresql.org/docs/current/functions-window.html
|
2019-03-08 15:29:05 +00:00
|
|
|
|
|
|
|
* Use the *Estimated cost* field to specify a positive number representing the
|
|
|
|
estimated execution cost for the function, in units of cpu_operator_cost. If
|
|
|
|
the function returns a set, this is the cost per returned row.
|
|
|
|
* Use the *Estimated rows* field to specify a positive number giving the
|
|
|
|
estimated number of rows that the query planner should expect the function to
|
|
|
|
return. This is only allowed when the function is declared to return a set.
|
|
|
|
The default assumption is 1000 rows.
|
|
|
|
* Move the *Leak proof?* switch to indicate whether the function has side
|
|
|
|
effects. The default is *No*. This option can only be set by the superuser.
|
2019-07-25 15:09:37 +00:00
|
|
|
* Use the *Support function* field to specify a planner support function to
|
|
|
|
use for the function.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
|
|
|
Click the *Parameters* tab to continue.
|
|
|
|
|
2016-05-20 20:39:21 +00:00
|
|
|
.. image:: images/function_parameters.png
|
2018-01-11 16:58:30 +00:00
|
|
|
:alt: Function dialog parameters tab
|
2019-03-08 15:29:05 +00:00
|
|
|
:align: center
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
Use the fields in the *Parameters* tab to specify settings that will be applied
|
|
|
|
when the function is invoked. Click the *Add* icon (+) to add a *Name*/*Value*
|
|
|
|
field in the table.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
* Use the drop-down listbox in the *Name* column in the *Parameters* panel to
|
|
|
|
select a parameter.
|
|
|
|
* Use the *Value* field to specify the value that will be associated with the
|
|
|
|
selected variable. This field is context-sensitive.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
|
|
|
Click the *Security* tab to continue.
|
|
|
|
|
2016-05-20 20:39:21 +00:00
|
|
|
.. image:: images/function_security.png
|
2018-01-11 16:58:30 +00:00
|
|
|
:alt: Function dialog security tab
|
2019-03-08 15:29:05 +00:00
|
|
|
:align: center
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2018-01-11 16:58:30 +00:00
|
|
|
Use the *Security* tab to assign privileges and define security labels.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
Use the *Privileges* panel to assign usage privileges for the function to a
|
|
|
|
role.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
|
|
|
* Select the name of the role from the drop-down listbox in the *Grantee* field.
|
2019-03-08 15:29:05 +00:00
|
|
|
* Click inside the *Privileges* field. Check the boxes to the left of one or
|
|
|
|
more privileges to grant the selected privilege to the specified user.
|
2019-11-26 03:03:59 +00:00
|
|
|
* The current user, who is the default grantor for granting the privilege, is displayed in the *Grantor* field.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
Click the *Add* icon (+) 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.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
Use the *Security Labels* panel to define security labels applied to the
|
|
|
|
function. Click the *Add* icon (+) to add each security label selection:
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
* Specify a security label provider in the *Provider* field. The named provider
|
|
|
|
must be loaded and must consent to the proposed labeling operation.
|
|
|
|
* Specify a a security label in the *Security Label* field. The meaning of a
|
|
|
|
given label is at the discretion of the label provider. PostgreSQL places no
|
|
|
|
restrictions on whether or how a label provider must interpret security
|
|
|
|
labels; it merely provides a mechanism for storing them.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
Click the *Add* icon (+) to assign additional security labels; to discard a
|
|
|
|
security label, click the trash icon to the left of the row and confirm deletion
|
|
|
|
in the *Delete Row* popup.
|
2016-05-13 13:43:57 +00:00
|
|
|
|
|
|
|
Click the *SQL* tab to continue.
|
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
Your entries in the *Function* dialog generate a 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.
|
2016-05-24 12:47:35 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
Example
|
|
|
|
*******
|
2016-05-24 12:47:35 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
The following is an example of the sql command generated by selections made in
|
|
|
|
the *Function* dialog:
|
2016-05-24 12:47:35 +00:00
|
|
|
|
2016-05-20 20:39:21 +00:00
|
|
|
.. image:: images/function_sql.png
|
2018-01-11 16:58:30 +00:00
|
|
|
:alt: Function dialog sql tab
|
2019-03-08 15:29:05 +00:00
|
|
|
:align: center
|
2016-05-13 13:43:57 +00:00
|
|
|
|
2019-08-02 09:25:21 +00:00
|
|
|
The example demonstrates creating an *plpgsql* function named *hire_salesmen*. The
|
|
|
|
function have three columns (p_ename, p_sal and p_comm).
|
2018-01-11 16:58:30 +00:00
|
|
|
|
2019-03-08 15:29:05 +00:00
|
|
|
* Click the *Info* button (i) to access online help.
|
2016-05-13 13:43:57 +00:00
|
|
|
* Click the *Save* button to save work.
|
2021-09-26 16:33:11 +00:00
|
|
|
* Click the *Close* button to exit without saving work.
|
2016-05-13 13:43:57 +00:00
|
|
|
* Click the *Reset* button to restore configuration parameters.
|