![]() |
VOOZH | about |
There are a vast number of PostgreSQL clients available on the Internet. From standard Drivers to BI and Analytics tools, PostgreSQL is a popular interface for data access. Using the SQL Gateway included in our ODBC Drivers, you can now create PostgreSQL entry-points that you can connect to from any standard client.
To access Dynamics 365 data as a PostgreSQL database on Windows, use the CData SQL Gateway, the ODBC Driver for Dynamics 365, and the MySQL foreign data wrapper from EnterpriseDB. In this article, we compile the foreign data wrapper in Visual Studio, install it as an extension, and query Dynamics 365 data from PostgreSQL Server.
CData simplifies access and integration of live Microsoft Dynamics 365 data. Our customers leverage CData connectivity to:
CData customers use our Dynamics 365 connectivity solutions for a variety of reasons, whether they're looking to replicate their data into a data warehouse (alongside other data sources) or analyze live Dynamics 365 data from their preferred data tools inside the Microsoft ecosystem (Power BI, Excel, etc.) or with external tools (Tableau, Looker, etc.).
If you have not already, first specify connection properties in an ODBC DSN (data source name). This is the last step of the driver installation. You can use the Microsoft ODBC Data Source Administrator to create and configure ODBC DSNs.
Edition and OrganizationUrl are required connection properties. The Dynamics 365 connector supports connecting to the following editions: CustomerService, FieldService, FinOpsOnline, FinOpsOnPremise, HumanResources, Marketing, ProjectOperations and Sales.
For Dynamics 365 Business Central, use the separate Dynamics 365 Business Central driver.
OrganizationUrl is the URL to your Dynamics 365 organization. For instance, https://orgcb42e1d0.crm.dynamics.com
The MySQL remoting service is a daemon process that listens for clients' incoming MySQL connections. See the setup guide in the SQL Gateway overview to configure the MySQL Remoting service in the CData SQL Gateway.
The Foreign Data Wrapper can be installed as an extension to PostgreSQL, without recompiling PostgreSQL. If you are running PostgreSQL on a Unix-based system, you can use the PostgreSQL Extension Network (PGXN) to install the FDW, mysql_fdw. If you are running PostgreSQL on Windows, compile the extension to ensure that you are working with the latest version. Follow the steps below to make the necessary modifications to build the extension from Visual Studio:
To build the foreign data wrapper, do the following:
After you have obtained the necessary software and source code, you are ready to compile the extension with Visual Studio. Follow the steps below to create a project using the mysql_fdw source:
Follow the steps below to configure your project:
Follow the steps below to add the required dependencies:
postgres.lib libmysql.lib WS2_32.lib Secur32.libAdditionally, ensure that Inherit From Parent or Project Defaults is checked.
MyMySQLConnectorCInstallation\include MyPostgreSQLInstallation\MyPostgreSQLVersion\include\server\port\win32_msvc MyPostgreSQLInstallation\MyPostgreSQLVersion\include\server\port\win32 MyPostgreSQLInstallation\MyPostgreSQLVersion\include\server MyPostgreSQLInstallation\MyPostgreSQLVersion\include
After setting up a project, make the following changes to build mysql_fdw in Visual Studio:
#define dlsym(lib, name) (void*)GetProcAddress((HMODULE)lib, name) #define dlopen(libname, unused) LoadLibraryEx(libname, NULL, 0)
mysql_dll_handle = dlopen(_MYSQL_LIBNAME, RTLD_LAZY | RTLD_DEEPBIND);
mysql_dll_handle = dlopen("libmysql.dll", 0);
__declspec(dllexport) extern Datum mysql_fdw_handler(PG_FUNCTION_ARGS);
__declspec(dllexport) extern Datum mysql_fdw_validator(PG_FUNCTION_ARGS);
You can now select the Release configuration and build.
After you have compiled the DLL, follow the steps below to install the extension:
After you have installed the extension, follow the steps below to start executing queries to Dynamics 365 data:
C:\> psql -U postgres
postgres=#CREATE EXTENSION mysql_fdw;
postgres=# CREATE SERVER Dynamics365 FOREIGN DATA WRAPPER mysql_fdw OPTIONS (host '127.0.0.1', port '3306');
postgres=# CREATE USER MAPPING for postgres SERVER Dynamics365 OPTIONS (username 'admin', password 'test');
postgres=# CREATE SCHEMA Dynamics365_db;
postgres=# IMPORT FOREIGN SCHEMA "CData Dynamics365 Sys" FROM SERVER Dynamics365 INTO Dynamics365_db;
You can now execute read/write commands to Dynamics 365:
postgres=# SELECT * FROM Dynamics365_db."goalheadings";
Download a free trial of the Dynamics 365 ODBC Driver to get started:
Download NowLearn more:
👁 Dynamics 365 IconThe Dynamics 365 ODBC Driver is a powerful tool that allows you to connect with live data from Dynamics 365, directly from any applications that support ODBC connectivity.
Access Dynamics 365 data like you would a database - read, write, and update Dynamics 365 Leads, Contacts, Opportunities, Accounts, etc. through a standard ODBC Driver interface.