ESRI Personal Geodatabase (MDB)

ESRI Personal Geodatabases are basically Microsoft Access files that contain spatial information. For more information see the ESRI description page.

File listing

Similar to other database formats, the mdb file consists of several tables. The geometry is held in a BLOB table column.

Data Access / Connection Method

Personal geodatabase access is available through OGR. See the OGR driver page for specific driver information. The driver is standard in any win32 build of GDAL/OGR version 1.3.2 or later. For Linux/Unix, MDBTools ODBC drivers can be used for this (with some difficulty).

OGR uses the names of spatial tables within the personal geodatabase (tables with a Shape column) as layers.

The CONNECTION parameter must include the mdb extension, and the DATA parameter should be the name of the spatial table (or OGR layer).

CONNECTIONTYPE ogr
CONNECTION "pgeodatabase.mdb"
DATA "layername"

OGRINFO Examples

First you should make sure that your GDAL/OGR build contains the personal geodatabase "PGeo" driver, by using the '--formats' command:

>ogrinfo --formats

   Loaded OGR Format Drivers:
   ...
   -> "ODBC" (read/write)
   -> "PGeo" (readonly)
   -> "PostgreSQL" (read/write)
   ...

If you don't have the driver, you might want to try the FWTools or MS4W packages, which include the driver.

Once you have the PGeo driver you are ready to try an ogrinfo command on your database to get a list of spatial tables:

>ogrinfo test.mdb

   INFO: Open of `test.mdb'
   using driver `PGeo' successful.
   1: counties

Now use ogrinfo to get information on the structure of the spatial table:

>ogrinfo test.mdb counties -summary

   INFO: Open of `test.mdb'
   using driver `PGeo' successful.

   Layer name: counties
   Geometry: Unknown (any)
   Feature Count: 67
   Extent: (-87.634943, 24.543945) - (-80.031369, 31.000975)
   Layer SRS WKT:
   GEOGCS["GCS_WGS_1984",
      DATUM["WGS_1984",
      SPHEROID["WGS_1984",6378137.0,298.257223563]],
      PRIMEM["Greenwich",0.0],
      UNIT["Degree",0.0174532925199433]]
   OBJECTID_1: Integer (10.0)
   OBJECTID: Integer (10.0)
   NAME: String (32.0)
   STATE_NAME: String (25.0)
   STATE_FIPS: String (2.0)
   CNTY_FIPS: String (3.0)
   FIPS: String (5.0)
   ...

Note that you can also use an ODBC connection to access all of the tables in your geodatabase:

>ogrinfo PGeo:testDSN counties -summary

   INFO: Open of `testDSN'
   using driver `PGeo' successful.

   1: counties
   2: counties_Shape_Index
   ...

(where "testDSN" is the name of your System DSN)

Mapfile Example

Direct Access to MDB

LAYER
  NAME my_geodatabase
  TYPE POLYGON
  CONNECTIONTYPE ogr
  CONNECTION "test.mdb"
  DATA "counties"
  PROCESSING "CLOSE_CONNECTION=DEFER" # for maximum performance
  STATUS ON
  CLASS
    NAME "counties"
    STYLE
      COLOR 255 255 120
    END
  END
END

Through an ODBC Connection

LAYER
  NAME my_geodatabase
  TYPE POLYGON
  CONNECTIONTYPE ogr
  CONNECTION "PGeo:testDSN"
  DATA "counties"
  PROCESSING "CLOSE_CONNECTION=DEFER" # for maximum performance
  STATUS ON
  CLASS
    NAME "counties"
    STYLE
      COLOR 255 255 120
    END
  END
END