Extensions
PostgreSQL extensions are add-on modules that extend the functionality of your database beyond the core features. They provide additional data types, functions, operators, indexes, and other capabilities without requiring modifications to the PostgreSQL source code.
Extensions work by packaging related database objects (functions, data types, operators, etc.) into a single installable unit. When you install an extension, PostgreSQL loads the necessary code and creates the required database objects in your database schema. This modular approach allows you to add only the functionality you need while keeping your database lightweight and maintainable.
Warning
Extensions configured through the dashboard may require a database restart and can impact performance. Consider the resource implications before enabling resource-intensive extensions.
Types of Extensions
PostgreSQL extensions generally fall into two main categories:
Native Extensions
These are extensions that ship with PostgreSQL itself and are maintained by the PostgreSQL core team. Examples include:
- Data type extensions:
citext
,hstore
,uuid-ossp
for specialized data types - Index extensions:
btree_gin
,btree_gist
for advanced indexing capabilities - Text search extensions:
unaccent
,pg_trgm
for full-text search enhancements - Utility extensions:
pgcrypto
for cryptographic functions,tablefunc
for table manipulation
Community Extensions
These are developed and maintained by the community or third-party organizations. Popular examples include:
- Vector search:
pgvector
for AI/ML vector operations - Query optimization:
pg_hint_plan
for query plan hints - Partitioning:
pg_partman
for automated table partitioning
Managing Extensions
Warning
Some extension operations may require a database restart to take effect, while others are applied immediately. Extensions that modify shared memory settings, background worker processes, or core database functionality typically require a restart. Most simple extensions like data types or functions can be installed without a restart.
Installing an Extension
To install an extension in your database, use the CREATE EXTENSION
command:
CREATE EXTENSION IF NOT EXISTS pgcrypto;
Removing an Extension
To remove an extension from your database, use the DROP EXTENSION
command:
DROP EXTENSION IF EXISTS pgcrypto;
Updating an Extension
To update an extension to a newer version, use the ALTER EXTENSION
command:
ALTER EXTENSION pgcrypto UPDATE;
Viewing Installed Extensions
To see all extensions currently installed in your database, use this query:
SELECT name, default_version, installed_version, comment FROM pg_available_extensions WHERE installed_version IS NOT NULL ORDER BY name;
To view all available extensions (both installed and available for installation):
SELECT name, default_version, comment FROM pg_available_extensions ORDER BY name;
Installing Extensions in Specific Schemas
By default, extensions are installed in the public
schema. To install an extension in a specific schema:
CREATE EXTENSION IF NOT EXISTS pgcrypto SCHEMA my_schema;
To move an existing extension to a different schema:
ALTER EXTENSION pgcrypto SET SCHEMA new_schema;
Note: Not all extensions support being installed in non-public schemas. Most utility and data type extensions work fine, but some system-level extensions must remain in the public schema.
Troubleshooting
Common Extension Issues
Extension not found
ERROR: extension "extension_name" is not available
This means the extension is not installed on the server or not supported. Check the supported extensions list below.
Permission denied
ERROR: permission denied to create extension "extension_name"
Extensions typically require database owner or superuser privileges. Contact support if you encounter permission issues.
Extension already exists
ERROR: extension "extension_name" already exists
Use CREATE EXTENSION IF NOT EXISTS extension_name;
to avoid this error, or check installed extensions first.
Dependency conflicts
ERROR: required extension "dependency_name" is not installed
Some extensions depend on others. Install the required dependency first, then retry installing your desired extension.
Supported Extensions
Supported Native Extensions
Name | Extension Version | Description |
---|---|---|
btree_gin | 1.3 | Provides GIN operator classes that implement B-tree equivalent behavior for various data types |
btree_gist | 1.7 | Provides GiST index operator classes that implement B-tree equivalent behavior |
citext | 1.6 | Provides case-insensitive character string type |
cube | 1.5 | Data type for representing multidimensional cubes |
dict_int | 1.0 | Text search dictionary template for integers |
fuzzystrmatch | 1.2 | Functions for determining similarities and distance between strings |
hstore | 1.8 | Data type for storing sets of key/value pairs within a single PostgreSQL value |
intarray | 1.5 | Functions and operators for manipulating null-free arrays of integers |
isn | 1.2 | Data types for international product numbering standards |
lo | 1.1 | Support for managing Large Objects (also called BLOBs) |
ltree | 1.2 | Data type for representing labels of data stored in hierarchical tree-like structures |
pg_stat_statements | 1.10 | Provides a means for tracking planning and execution statistics of all SQL statements |
pg_trgm | 1.6 | Functions and operators for determining the similarity of alphanumeric text based on trigram matching |
pgcrypto | 1.3 | Cryptographic functions for PostgreSQL |
plpgsql | 1.0 | Loadable procedural language for the PostgreSQL database system |
seg | 1.4 | Data type for representing line segments or floating-point intervals |
tablefunc | 1.0 | Functions that return tables (multiple rows) |
tcn | 1.0 | Provides a trigger function that notifies listeners of changes to any table |
tsm_system_rows | 1.0 | Table sampling method SYSTEM_ROWS which can be used in TABLESAMPLE clause |
tsm_system_time | 1.0 | Table sampling method SYSTEM_TIME which can be used in TABLESAMPLE clause |
unaccent | 1.1 | Text search dictionary for removing accents (diacritic signs) from lexemes |
uuid-ossp | 1.1 | Functions to generate universally unique identifiers (UUIDs) |
Supported Community Extensions
Name | Extension Version | Description |
---|---|---|
address_standardizer | 3.5.3 | Used to parse an address into constituent elements. Generally used to support geocoding address normalization step. (Part of PostGIS) |
address_standardizer_data_us | 3.5.3 | Address Standardizer US dataset example. (Part of PostGIS) |
pg_hint_plan | 1.6 | Provides query plan hints to control the PostgreSQL planner |
pg_partman | 5.0 | Extension to create and manage both time-based and serial-based table partition sets |
pgvector | 0.7 | Open-source vector similarity search for PostgreSQL, designed for AI/ML applications |
postgis | 3.5.3 | PostGIS extends the capabilities of the PostgreSQL relational database by adding support for storing, indexing, and querying geospatial data. |
postgis_sfcgal | 3.5.3 | SFCGAL is a C++ wrapper library around CGAL that provides advanced 2D and 3D spatial functions. |
postgis_tiger_geocoder | 3.5.3 | A plpgsql based geocoder written to work with the TIGER (Topologically Integrated Geographic Encoding and Referencing system ) / Line and Master Address database export released by the US Census Bureau. |
postgis_topology | 3.5.3 | The PostGIS Topology types and functions are used to manage topological objects such as faces, edges and nodes. |
Need Additional Extensions?
If you require an extension that is not currently supported, please reach out to support. We regularly evaluate and add new extensions based on customer needs and security considerations.
Configuring Extensions in the Dashboard
Some extensions require explicit configuration through the PlanetScale dashboard and may consume additional resources on your database instances. These extensions often have configurable parameters that need to be set according to your specific use case.
Dashboard Configuration
To configure extensions through the dashboard:
- From the PlanetScale organization dashboard, select the desired database
- Navigate to the Cluster configuration page from the menu on the left
- Choose the branch whose parameters you'd like to configure in the "Branch" dropdown
- Select the Extensions tab
- Enable the desired extensions and configure their parameters
- Click Queue extension changes to apply the configuration
- Once you're ready to apply the changes, click "Apply changes"
Extensions with Dashboard Configuration
pg_cron
- Can be enabled through the dashboard
- Has no additional parameters
pg_hint_plan
- Requires enabling through the dashboard
- Configurable parameters include:
pg_hint_plan.enable_hint
- Enable/disable hint functionalitypg_hint_plan.enable_hint_table
- Enable hint table functionalitypg_hint_plan.parse_messages
- Control parsing message outputpg_hint_plan.debug_print
- Enable debug outputpg_hint_plan.message_level
- Set message verbosity level
pg_stat_statements
- Requires enabling through the dashboard
- Configurable parameters include:
pg_stat_statements.max
- Maximum number of statements trackedpg_stat_statements.track
- Which statements to trackpg_stat_statements.track_utility
- Track utility statementspg_stat_statements.track_planning
- Track planning statisticspg_stat_statements.save
- Save statistics across server restarts
Note: Some extensions like pgextwlist
and pginsights
are always enabled for PlanetScale databases and don't require manual configuration.
Need help?
Get help from the PlanetScale Support team, or join our GitHub discussion board to see how others are using PlanetScale.