- ArcSDE
- GDAL
- Oracle (King.Oracle)
- MySQL
- ODBC
- OGR
- PostGIS (old one)
- PostgreSQL (new one)
- SDF
- SHP
- SQLite
- MS SQL Server Spatial (>= 2008)
- WFS
- WMS
- ArcSDE
- Oracle (King.Oracle)
- MySQL
- PostGIS (old one)
- PostgreSQL (new one)
- Licensing restrictions preventing component redistribution (ArcSDE)
- Substantially increased installer footprint (Oracle)
- The components that are bundled (if we did bundle them) may be older or newer than what is provided by your existing DBMS installation (MySQL, PostgreSQL)
- Any combination of the above points.
So what exactly do you need to do for each provider?
For ArcSDE:
- Here's an old (but still relevant) blog post detailing how to set up the ArcSDE FDO provider for AutoCAD Map. It is equally applicable to MapGuide
- Here's a blog post straight from the horse's mouth detailing how to troubleshoot common problems with this provider. Once again, despite the AutoCAD Map focus it is equally applicable to MapGuide as both products use FDO.
- Here's a readme from the author of this provider (sl-king), detailing the configuration you need to do with the Oracle Instant Client
- You need to ensure that libmysql.dll from your MySQL installation is either in the same directory as the FDO provider dll, or the path to libmysql.dll is in the PATH environment variable (which is what Windows will use to search for dlls that need to be loaded). If you are installing MapGuide on the same machine where MySQL is installed, you shouldn't need to do anything.
- You need to ensure that libpq.dll (and its dependencies) from your PostgreSQL installation is either in the same directory as the FDO provider dll, or the path to libpq.dll is in the PATH environment variable (which is what Windows will use to search for dlls that need to be loaded). If you are installing MapGuide on the same machine where PostgreSQL is installed, you shouldn't need to do anything.
Notice the question mark on OCI.dll? OCI.dll is part of the Oracle Instant Client which the King.Oracle provider requires to properly function. A question mark indicates that this dll could not be found.
So the solution is to ensure that OCI.dll (and its dependencies) are located in a directory that Windows will search dlls for. Reloading the provider dll in Dependency Walker should no longer show a question mark beside OCI.dll meaning that the provider dll has all its dependencies satisfied, meaning this provider should now be fully functional.
One more thing about this: If you did have to carry out any of these extra configuration steps, remember to restart your MapGuide Server if it is already running.
So in summary:
- Some FDO providers are not installed by default because they require additional components. These components are not bundled into the installer for reasons explained in this post.
- This post should hopefully point you in the right direction to configure and troubleshoot these providers should you choose to install them.
This solved all my FDO problems / questions :) Thank you !
ReplyDeleteHi
ReplyDeleteI follow with the same error of "unable to load the FDO Provider library '.\PostgreSQLProvider.dll'
I have in the same machine PostgreSQL 9.3 y Mapguide 2.5. But in the ..\osgeo\mapguide\Server\FDO\ i had not the libpq.dll. I have put it in but is not necessary to register it with rgsvr32?
Anyway I have adde to Path variable the path: "c:\PostgreSQL\9.3\lib\"
But nothing works