PostgreSQL
On This Page
Starting Release 2.19, Hevo has stopped supporting XMIN as a query mode for all variants of the PostgreSQL Source. As a result, you will not be able to create new Pipelines using this query mode. This change does not affect existing Pipelines. However, you will not be able to change the query mode to XMIN for any objects currently ingesting data using other query modes.
Hevo supports the following variations of PostgreSQL as a Source:
Hevo recommends logical replication as the default mode to ingest incremental data from your PostgreSQL Source database, especially for high transaction volumes. However, you can also select a different ingestion mode, such as Table, XMIN, or Custom SQL.
Refer to the required PostgreSQL variant for the steps to configure it as a Source in your Hevo Pipeline and start ingesting data.
Resolving Data Loss in Paused Pipelines
For Pipelines created with Logical Replication ingestion mode, Hevo replicates the data using the log generated by the Source. Pausing a log-based Pipeline for more than 24 hours may lead to data loss, as a result of the log being deleted. The log can get deleted due to the expiry of its retention period or limited disk storage space in the case of large log files.
In case there is a loss of data after resuming a paused Pipeline, restart the historical load for all the objects to ingest the lost data. To do so, in the Pipeline Overview page:
- 
    Select the Objects check box to select all the objects in the Pipeline. You can also select specific objects by selecting the check box next to their names.  
- 
    Select the Restart option from the MORE drop-down to start the historical data ingestion. 
The historical load starts immediately. The re-ingested data does not count towards your quota consumption and is not billed.
Dropping a Replication Slot
For Pipelines with Logical Replication as the Pipeline mode, Hevo creates a replication slot in the Source to capture changes from the Write-Ahead Logs (WAL). When the Pipeline is deleted, Hevo automatically drops this slot. However, in some cases, due to issues at the PostgreSQL Source end, the slot might not get dropped. If the slot remains, the database continues to store log files that are no longer needed, which may consume storage space allocated by the database for its logs.
Additionally, during a database upgrade or migration, PostgreSQL may remove or invalidate the replication slot. If the Pipeline using that slot remains active, it may lead to incomplete or missing data, as Hevo cannot read any changes from the logs. Read How can I prevent data loss when migrating or upgrading my PostgreSQL database? for more information.
In either of the scenarios above, you need to drop the replication slot manually to prevent potential data loss or storage issues. To do this, perform the following steps:
- 
    Connect to the PostgreSQL database configured in your Pipeline as a Superuser using an SQL client tool, such as psql. 
- 
    Run the following command to drop the slot: SELECT pg_drop_replication_slot('<slot_name>');For example, to drop a slot named test_postgreSQL_slot, run the following query:SELECT pg_drop_replication_slot('test_postgreSQL_slot');
Note: If you manually drop the replication slot for an active Pipeline, Hevo automatically creates a new slot to resume data ingestion. However, any changes made in the Source database while the slot was missing are not captured. To prevent data loss, you should restart the historical load for the Source objects being replicated in that Pipeline.
Handling Toast Data
PostgreSQL can efficiently store large amounts of data in columns using The Oversized-Attribute Storage Technique (TOAST). When a column’s value exceeds approximately 8 KB (the default page size), PostgreSQL compresses the data and may store it in a separate TOAST table. Columns managed in this way are referred to as TOASTed columns.
In log-based Pipelines, if a TOASTed column remains unchanged during an update but other columns are modified during ingestion, PostgreSQL omits the unchanged TOASTed data from Write-Ahead Logs (WAL). As a result, Hevo cannot replicate the data via logs and writes a null value in the Destination.
To prevent data loss, Hevo can temporarily store unprocessed TOASTed records in its temporary memory cache if there is a downtime or failure in its internal data processing system. When the system recovers, the cached data is processed.
If you observe null values in the TOASTed column in the Destination or want to enable temporary caching of TOASTed records, contact Hevo Support.
Source Considerations
- 
    When you delete a row in the Source table, its XMIN value is deleted as well. As a result, for Pipelines created with the XMIN ingestion mode, Hevo cannot track deletes in the Source object(s). To capture deletes, you need to restart the historical load for the respective object. 
- 
    XMIN is a system-generated column in PostgreSQL, and it cannot be indexed. Hence, to identify the updated rows in Pipelines created with the XMIN ingestion mode, Hevo scans the entire table. This action may lead to slower data ingestion and increased processing overheads on your PostgreSQL database host. Due to this, Hevo recommends that you create the Pipeline in the Logical Replication mode. 
Note: The XMIN limitations specified above are applicable only to Pipelines created using the XMIN ingestion mode, which is currently available for Early Access.
- PostgreSQL retains Write-Ahead Logs (WALs) until all replication clients, such as Hevo or other consumers, have acknowledged the receipt of relevant changes. In other words, PostgreSQL waits for each client to catch up to a certain point in the WAL stream before it can safely discard older logs. As a result, the WAL size may grow even though Hevo consistently ingests new changes without lag and has no backlog. This growth can be due to long-running transactions, inactive or lagging replicas, or delays in PostgreSQL’s internal cleanup. If the WAL size exceeds the retention threshold, PostgreSQL may drop the replication slot, causing Pipeline failure. To prevent this, monitor long-running transactions and ensure other replication clients are progressing as expected. Read Viewing Statistics in PostgreSQL.
Revision History
Refer to the following table for the list of key updates made to this page:
| Date | Release | Description of Change | 
|---|---|---|
| Jul-10-2025 | NA | Updated the Dropping a Replication Slot Post-Pipeline Deletion section to: - Rename it to Dropping a Replication Slot, - Add a scenario where the historical load needs to be restarted for objects if the slot is dropped. | 
| Jun-23-2025 | NA | Updated section, Source Considerations to add information about WAL size growth issue in PostgreSQL. | 
| Jun-23-2025 | NA | Added section, Handling Toast Data to add information about how Hevo handles Toast data. | 
| Apr-29-2024 | NA | Removed sections, Select the Source Type and Specify PostgreSQL Connection Settings. | 
| Mar-05-2024 | NA | Updated links. | 
| Jan-10-2024 | NA | - Added section, Source Considerations. - Removed mentions of XMIN as a query mode. | 
| Nov-03-2023 | NA | Removed section, Object Settings. | 
| Jun-28-2023 | 2.14 | Updated section, Object Settings to add information about the default query mode. | 
| Feb-07-2023 | 2.07 | Updated the page for clarity. | 
| Apr-21-2022 | 1.86 | - Updated sections, Specify PostgreSQL Connection Settings and Object Settings. - Removed section, Select the Pipeline Mode. | 
| Mar-07-2022 | 1.83 | Updated the section, Select the Pipeline Mode with a note about the logical replication. | 
| Jan-24-2022 | 1.80 | Added information about the impact of pausing a Pipeline in the Source Considerations section. | 
| Jan-03-2022 | 1.79 | Updated the description of the Include New Tables in the Pipeline advance setting in the Specify PostgreSQL Connection Settings section. | 
| Dec-06-2021 | 1.77 | Added section, Source Considerations. | 
| Jul-26-2021 | 1.68 | Added a note for the Database Host field. | 
| Jul-12-2021 | 1.67 | Added the field Include New Tables in the Pipeline under Source configuration settings. |