Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Summary
| Item | Description | 
|---|---|
| Release State | General Availability | 
| Products | Excel Power BI (Semantic models) Power BI (Dataflows) Fabric (Dataflow Gen2) Power Apps (Dataflows) Dynamics 365 Customer Insights Analysis Services | 
| Authentication Types Supported | Database (Username/Password) Microsoft account (Microsoft Entra ID) | 
| Function Reference Documentation | PostgreSQL.Database | 
Note
Some capabilities might be present in one product but not others due to deployment schedules and host-specific capabilities.
Prerequisites
Power BI Desktop has included the Npgsql provider for PostgreSQL connector since December 2019, eliminating the need for additional installation. Starting with the October 2024 version, it incorporates Npgsql version 4.0.17. Separate Npgsql GAC installation will override this default version.
The PostgreSQL connector is supported for cloud connection and via VNet data gateway or on-premises data gateway. Since the June 2025 release, the on-premises data gateway includes the Npgsql provider, so no extra installation is needed. Separate Npgsql GAC installation will override this default version.
For Power BI Desktop versions released before December 2019 and on-premises data gateway released before June 2025, you must install the Npgsql provider on your local machine to use the PostgreSQL connector. To install the Npgsql provider, go to the releases page for version 4.0.17, download and run the .msi file. The provider architecture (32-bit or 64-bit) needs to match the architecture of the product where you intend to use the connector. When installing, make sure that you select Npgsql GAC Installation to ensure Npgsql itself is added to your machine. Npgsql 4.1 and up are not supported due to .NET version incompatibilities.
 
Capabilities Supported
- Import
- DirectQuery (Power BI semantic models)
- Advanced options
- Command timeout in minutes
- Native SQL statement
- Relationship columns
- Navigate using full hierarchy
 
Connect to a PostgreSQL database from Power Query Desktop
Once the matching Npgsql provider is installed, you can connect to a PostgreSQL database. To make the connection, take the following steps:
- Select the PostgreSQL database option in the connector selection. For more information, go to Where to get data. 
- In the PostgreSQL database dialog that appears, provide the name of the server and database.   
- Select either the Import or DirectQuery data connectivity mode. 
- If you're connecting to this database for the first time, select the authentication type you want to use, and then enter your credentials. The authentication types available are: - Database (Username and password)
- Microsoft account (Microsoft Entra ID)
 - For more information about authentication, go to Authentication with a data source.   
- If the connection isn't encrypted, you're prompted with the following message.   - Select OK to connect to the database by using an unencrypted connection. If an encrypted connection is desired, the PostgreSQL server must be set up to accommodate SSL connections (go to the PostgreSQL documentation for guidance). Once completed, your machine might be required to install the PostgreSQL server's SSL certificate into its Trusted Root Certification Authorities. 
- In Navigator, select the database information you want, then either select Load to load the data or Transform Data to continue transforming the data in Power Query editor. 
Connect to a PostgreSQL database from Power Query Online
To make the connection, take the following steps:
- Select the PostgreSQL database option in the connector selection. For more information, go to Where to get data. 
- In the PostgreSQL database dialog that appears, provide the name of the server and database.   
- Select the name of the on-premises data gateway you want to use. 
- Select the Basic authentication kind and input your PostgreSQL credentials in the Username and Password boxes. 
- If your connection isn't encrypted, clear Use Encrypted Connection. 
- Select Next to connect to the database. 
- In Navigator, select the data you require, then select Transform data to transform the data in Power Query editor. 
Connect using advanced options
Power Query Desktop provides a set of advanced options that you can add to your query if needed.
 
The following table lists all of the advanced options you can set in Power Query Desktop.
| Advanced option | Description | 
|---|---|
| Command timeout in minutes | If your connection lasts longer than 10 minutes (the default time-out), you can enter another value in minutes to keep the connection open longer. This option is only available in Power Query Desktop. | 
| SQL statement | For information, go to Import data from a database using native database query. | 
| Include relationship columns | If checked, includes columns that might have relationships to other tables. If this box is cleared, those columns aren't displayed. | 
| Navigate using full hierarchy | If checked, the navigator displays the complete hierarchy of tables in the database you're connecting to. If cleared, the navigator displays only the tables whose columns and rows contain data. | 
Once you select the advanced options you require, select OK in Power Query Desktop to connect to your PostgreSQL database.
Native query folding
By default, native query folding is enabled. Operations that are capable of folding are applied on top of your native query according to normal Import or Direct Query logic. Native Query folding isn't applicable with optional parameters present in Value.NativeQuery.
In the rare case that folding doesn't work with native query folding enabled, you can disable it. To disable native query folding, set the EnableFolding flag to false for Value.NativeQuery in the advanced editor.
Sample:
Value.NativeQuery(target as any, query, null, [EnableFolding=false])
Troubleshooting
Your native query might throw the following error:
We cannot fold on top of this native query. Please modify the native query or remove the 'EnableFolding' option.
A basic troubleshooting step is to check if the query in Value.NativeQuery throws the same error with a limit 1 clause around it:
select * from (query) _ limit 1
