Power BI with DuckDB and MotherDuck
Power BI is an interactive data visualization product developed by Microsoft. MotherDuck has built an open-source DuckDB Power Query Connector that you can use to connecto Power BI to DuckDB and MotherDuck.
Installing
- Download the latest DuckDB ODBC driver from the DuckDB Power Query Connector GitHub Releases for Windows:
- Extract the
.zip
archive into a permanent location, such asC:\Program Files\duckdb_odbc
. Runodbc_install.exe
- if Windows displays a security warning, click "More information" then "Run Anyway". - Optionally, verify the installation in the Registry Editor:
- Open Registry Editor by running
regedit
- Navigate to
HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI\DuckDB
- Confirm the Driver field shows your installed version
- If incorrect, delete the
DuckDB
registry key and reinstall
- Open Registry Editor by running
- Configure Power BI security settings to allow loading of custom extensions:
- Go to File -> Options and settings -> Options -> Security -> Data Extensions
- Enable "Allow any extensions to load without validation or warning"
- Download the latest version of the DuckDB Power Query extension:
- Create the Custom Connectors directory if it does not yet exist:
- Navigate to
[Documents]\Power BI Desktop\Custom Connectors
- Create this folder, if it doesn't exist
- Note: If this location does not work you may need to place this in your OneDrive Documents folder instead
- Navigate to
- Copy the
duckdb-power-query-connector.mez
file into the Custom Connectors folder - Restart Power BI Desktop
How to use with Power BI
- In Power BI Desktop, click "Get Data" -> "More..."
- Search for "DuckDB" in the connector search box and select the DuckDB connector
- For MotherDuck connections, you'll need to provide:
- Database Location: Use the
md:
prefix followed by your database name (e.g.,md:my_database
). This can also be a local file path (e.g.,~\my_database.db
) - MotherDuck Token: Get your token from MotherDuck's token page
- Read Only (Optional): Set to
true
if you only need read access
- Database Location: Use the
- Click "OK".
- Click "Connect".
- Select the table(s) you want to import. Click "Load".
- You can now query your data and create visualizations!
- After connecting, you can:
- Browse and select tables from your MotherDuck or DuckDB database
- Use "Transform Data" to modify your queries before loading
- Write custom SQL queries using the "Advanced Editor"
- Import multiple tables in one go
- Power BI will maintain the connection to your MotherDuck or DuckDB database, allowing you to:
- Refresh data automatically or on-demand
- Create relationships between tables
- Build visualizations and dashboards
- Share reports with other users (requires proper gateway setup)
Use custom data connectors with an on-premises data gateway
You can use custom data connectors with an on-premises data gateway to connect to data sources that are not supported by default. To do this, you need to install the on-premises data gateway and configure it to use the custom data connector. For more information, see Use custom data connectors with an on-premises data gateway in Power BI.
It should be noted that there are some limitations with using a custom connector with an on-premise data gateway:
- Make sure the folder you create is accessible to the background gateway service. Typically, folders under your users' Windows folders or system folders aren't accessible. The on-premises data gateway app shows a message if the folder isn't accessible. This limitation doesn't apply to the on-premises data gateway (personal mode).
- If your custom connector is on a network drive, include the fully qualified path in the on-premises data gateway app.
- You can only use one custom connector data source when working in DirectQuery mode. Multiple custom connector data sources don't work with DirectQuery.
Additional information
Troubleshooting
Missing VCRUNTIME140.dll
If you receive an error about missing VCRUNTIME140.dll
, you need to install the Microsoft Visual C++ Redistributable. You can download it from Microsoft's download page.
Visual C++ and ODBC Issues
These steps are particularly relevant for Windows Server environments, especially for Windows Server 2019, but may also help resolve issues on other Windows versions.
If you encounter issues with ODBC connectivity or receive errors related to Visual C++ libraries, try these troubleshooting steps:
-
Reinstall the Microsoft Visual C++ Redistributable:
- Download the latest version from Microsoft's official website for your architecture
- Run the installer with administrator privileges
- Restart your computer after installation
- Try connecting to MotherDuck again
-
If you're still experiencing issues, you can use the ODBC Test tool to diagnose the connection:
- Open the ODBC Test tool (typically available in Windows SDK)
- Look for a dropdown menu labeled "hstmt 1: ..."
- Select this option to run test queries
- If queries work in the ODBC Test tool but not in Power BI, this indicates a Power BI-specific configuration issue
If you continue to experience problems after trying these steps, please:
- Verify that your MotherDuck token is valid and hasn't expired
- Check that your network allows connections to MotherDuck's services
- Ensure you have the latest version of the DuckDB Power Query Connector installed
If you're still experiencing issues, please reach out to us at support@motherduck.com and we'll be happy to help you troubleshoot the issue.