mirror of
https://github.com/pgadmin-org/pgadmin4.git
synced 2024-12-31 11:17:24 -06:00
a43b70e360
2. Added USING method while creating the materialized view. #6400
136 lines
5.7 KiB
ReStructuredText
136 lines
5.7 KiB
ReStructuredText
.. _materialized_view_dialog:
|
|
|
|
*********************************
|
|
`Materialized View Dialog`:index:
|
|
*********************************
|
|
|
|
Use the *Materialized View* dialog to define a materialized view. A materialized
|
|
view is a stored or cached view that contains the result set of a query. Use
|
|
the REFRESH MATERIALIZED VIEW command to update the content of a materialized
|
|
view.
|
|
|
|
The *Materialized View* dialog organizes the development of a materialized_view
|
|
through the following dialog tabs: *General*, *Definition*, *Storage*,
|
|
*Parameter*, and *Security*. The *SQL* tab displays the SQL code generated by
|
|
dialog selections.
|
|
|
|
.. image:: images/materialized_view_general.png
|
|
:alt: Materialized view dialog general tab
|
|
:align: center
|
|
|
|
Use the fields in the *General* tab to identify the materialized view:
|
|
|
|
* Use the *Name* field to add a descriptive name for the materialized view. The
|
|
name will be displayed in the *pgAdmin* tree control.
|
|
* Use the drop-down listbox next to *Owner* to select the role that will own
|
|
the materialized view.
|
|
* Select the name of the schema in which the materialized view will reside from
|
|
the drop-down listbox in the *Schema* field.
|
|
* Store notes about the materialized view in the *Comment* field.
|
|
|
|
Click the *Definition* tab to continue.
|
|
|
|
.. image:: images/materialized_view_definition.png
|
|
:alt: Materialized view dialog storage tab
|
|
:align: center
|
|
|
|
Use the fields in the *Storage* tab to maintain the materialized view:
|
|
|
|
* Move the *With Data* switch to the *Yes* position to specify the materialized
|
|
view should be populated at creation time. If not, the materialized view
|
|
cannot be queried until you invoke REFRESH MATERIALIZED VIEW.
|
|
* Use the drop-down listbox next to *Tablespace* to select a location for the
|
|
materialized view.
|
|
* Use the drop-down list box next to Access Method to specify the table access method to use to store the contents
|
|
for the new materialized view; the method needs to be an access method of type TABLE. This field is optional.
|
|
This option is available from v12 and above.
|
|
* Use the *Fill Factor* field to specify a fill factor for the materialized
|
|
view. The fill factor for a table is a percentage between 10 and 100. 100
|
|
(complete packing) is the default.
|
|
|
|
Click the *Code* tab to continue.
|
|
|
|
.. image:: images/materialized_view_code.png
|
|
:alt: Materialized view dialog definition tab
|
|
:align: center
|
|
|
|
Use the text editor field in the *Code* tab to provide the query that will
|
|
populate the materialized view. Please note that updating the definition of existing
|
|
materialized view would result in loss of Parameter(Table, Toast), Security(Privileges & Security labels),
|
|
Indexes and other dependent objects.
|
|
|
|
Click the *Parameter* tab to continue.
|
|
|
|
.. image:: images/materialized_view_parameter.png
|
|
:alt: Materialized view dialog parameter tab
|
|
:align: center
|
|
|
|
Use the tabs nested inside the *Parameter* tab to specify VACUUM and ANALYZE
|
|
thresholds; use the *Table* tab and the *Toast Table* tab to customize values
|
|
for the table and the associated toast table. To change the default values:
|
|
|
|
* Move the *Custom auto-vacuum?* switch to the *Yes* position to perform custom
|
|
maintenance on the materialized view and to select values in the
|
|
*Vacuum table*. The *Vacuum Table* provides default values for maintenance
|
|
operations.
|
|
* Changing *Autovacuum enabled?* to *Not set* will reset autovacuum_enabled.
|
|
|
|
Click the *Security* tab to continue.
|
|
|
|
.. image:: images/materialized_view_security.png
|
|
:alt: Materialized view dialog security tab
|
|
:align: center
|
|
|
|
Use the *Security* tab to assign privileges and define security labels.
|
|
|
|
Use the *Privileges* panel to assign privileges to a role. Click the *Add* icon
|
|
(+) to set privileges for the materialized view:
|
|
|
|
* 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 privilege to the specified user.
|
|
* The current user, who is the default grantor for granting the privilege, is displayed in the *Grantor* field.
|
|
|
|
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.
|
|
|
|
Use the *Security Labels* panel to define security labels applied to the
|
|
materialized view. Click the *Add* icon (+) to add each security label
|
|
selection:
|
|
|
|
* 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.
|
|
|
|
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.
|
|
|
|
Click the *SQL* tab to continue.
|
|
|
|
Your entries in the *Materialized View* 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 *Materialized View* dialog:
|
|
|
|
.. image:: images/materialized_view_sql.png
|
|
:alt: Materialized view dialog sql tab
|
|
:align: center
|
|
|
|
The example shown creates a query named *new_hires* that stores the result of
|
|
the displayed query in the *pg_default* tablespace.
|
|
|
|
* Click the *Info* button (i) to access online help.
|
|
* Click the *Save* button to save work.
|
|
* Click the *Close* button to exit without saving work.
|
|
* Click the *Reset* button to restore configuration parameters.
|