Manage PostgreSQL extensions
APPLIES TO: Azure Database for PostgreSQL - Flexible Server
Azure Database for PostgreSQL flexible server allows you to extend the functionality of your database using extensions. Extensions bundle multiple related SQL objects in a single package that can be loaded or removed from your database with a command. After being loaded into the database, extensions function like built-in features.
Allow extensions
Before installing extensions in Azure Database for PostgreSQL flexible server, you must allow these extensions to be listed for use.
Using the Azure portal:
Load libraries
shared_preload_libraries
is a server configuration parameter that determines which libraries have to be loaded when Azure Database for PostgreSQL flexible server starts. Any libraries that use shared memory must be loaded via this parameter. If your extension needs to be added to the shared preload libraries, follow these steps:
Using the Azure portal:
Select your Azure Database for PostgreSQL flexible server instance.
From the resource menu, under Settings section, select Server parameters.
Include the libraries you wish to add in the value of
shared_preload_libraries
, and select Save.Because
shared_preload_libraries
is a static server parameter, it requires a server restart so that the changes take effect.
Create extensions
After an extension is allowlisted and, if the extension requires it, is also added to shared_load_libraries
, it can be created or installed in each database on which it's to be used.
To create an extension, a user must be a member of the
azure_pg_admin
role.Run the CREATE EXTENSION command to create or install a particular extension. This command loads the packaged objects into your database.
Note
Third-party extensions offered in Azure Database for PostgreSQL flexible server are open-source licensed code. We don't offer any third-party extensions or extension versions with premium or proprietary licensing models.
Azure Database for PostgreSQL flexible server instance supports a subset of key PostgreSQL extensions, as listed in supported extensions by name or in supported extensions by version of PostgreSQL. This information is also available by running SHOW azure.extensions;
. Extensions not included in those lists aren't supported on Azure Database for PostgreSQL flexible server. You can't create or load your own extensions in Azure Database for PostgreSQL flexible server.
Drop extensions
To drop an extension, first make sure to allowlist it.
To drop an extension, a user must be a member of the
azure_pg_admin
role.Run the DROP EXTENSION command to drop or uninstall a particular extension. This command drops the objects packaged in the extension from your database.
Update extensions
To update an installed extension to the latest available version supported by Azure, use the following SQL command:
ALTER EXTENSION <extension_name> UPDATE;
This command simplifies the management of database extensions by allowing users to manually upgrade to the latest version approved by Azure, enhancing both compatibility and security.
Limitations
While updating extensions is straightforward, there are certain limitations:
Selection of a specific version: The command doesn't support updating to intermediate versions of an extension.
- It constantly updates the latest available version.
Downgrading: Doesn't support downgrading an extension to a previous version. If a downgrade is necessary, it might require support assistance and depends on the availability of the previous version.
View installed extensions
To list the extensions currently installed on your database, use the following SQL command:
SELECT * FROM pg_extension;
Possible errors
Extension "%s" is not allow-listed for "azure_pg_admin" users in Azure Database for PostgreSQL
This error occurs when you run a CREATE EXTENSION
or DROP EXTENSION
command referring to an extension that isn't allowlisted, or an extension that isn't supported yet on the instance of Azure Database for flexible server on which you're running the command.
Only members of "azure_pg_admin" are allowed to use CREATE EXTENSION
This error occurs when the user that runs a CREATE EXTENSION
command isn't a member of azure_pg_admin
role.
Only members of "azure_pg_admin" are allowed to use DROP EXTENSION
This error occurs when the user that runs a DROP EXTENSION
command isn't a member of azure_pg_admin
role.