2020-08-04 03:02:20 +08:00
|
|
|
|
[](https://travis-ci.org/evanmiller/mdbtools)
|
2020-08-05 05:09:23 +08:00
|
|
|
|
[](https://ci.appveyor.com/project/evanmiller/mdbtools/branch/master)
|
2018-02-07 03:47:30 +08:00
|
|
|
|
|
2020-08-10 03:23:38 +08:00
|
|
|
|
Yet another attempt to resuscitate MDB Tools – the Access-accessing C library
|
|
|
|
|
and command-line suite.
|
2018-02-07 03:47:30 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
This is a fork of a [fork](https://github.com/cyberemissary/mdbtools) of a
|
|
|
|
|
[fork](https://github.com/brjohnsn/mdbtools) of a
|
|
|
|
|
[fork](https://github.com/leecher1337/mdbtools) of the [original MDB
|
|
|
|
|
Tools](https://github.com/brianb/mdbtools) by Brian Buns. I got sick of seeing
|
|
|
|
|
the project waste away, so I'm taking the initiative to get MDB Tools
|
|
|
|
|
whipped back into shape and properly maintained.
|
2018-02-07 03:47:30 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
A brief history: the last *official* release (version 0.7.1) occurred in 2016.
|
|
|
|
|
[cyberemissary](https://github.com/cyberemissary) (whose work this fork is
|
|
|
|
|
based on) made a release in December 2018 and called it 0.8.2. *I am not
|
|
|
|
|
planning a formal release* but rather collecting and merging patches to submit
|
|
|
|
|
upstream. In the meantime you are welcome to use this code base:
|
2018-02-07 03:47:30 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
https://github.com/evanmiller/mdbtools
|
2018-02-07 03:47:30 +08:00
|
|
|
|
|
2020-08-10 03:23:38 +08:00
|
|
|
|
Intended focus areas of this fork:
|
2018-02-07 03:47:30 +08:00
|
|
|
|
|
2020-09-01 01:32:24 +08:00
|
|
|
|
- [x] Security / stability / fuzz testing
|
2020-08-22 08:44:47 +08:00
|
|
|
|
- [x] Thread safety\*
|
2020-09-01 01:03:58 +08:00
|
|
|
|
- [x] In-memory database API
|
2020-09-01 01:32:24 +08:00
|
|
|
|
- [x] Making GLib optional
|
2020-08-22 08:44:47 +08:00
|
|
|
|
- [x] Improved ODBC compliance
|
2020-08-10 03:23:38 +08:00
|
|
|
|
- [x] Continuous integration with Travis and AppVeyor
|
2018-02-14 02:54:34 +08:00
|
|
|
|
|
2020-08-22 08:44:47 +08:00
|
|
|
|
\* Multiple `MdbHandle`s can now be created on different threads – and
|
|
|
|
|
`MdbHandle`s can be passed between threads – but threads should not attempt to
|
|
|
|
|
use the same `MdbHandle` at the same time. Use `mdb_clone_handle` to create a
|
|
|
|
|
new handle using an existing file descriptor.
|
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
A re-formatted and updated README file follows.
|
2018-12-28 20:11:51 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
*In a chipper open-source voice...*
|
2018-02-14 02:54:34 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
Welcome to the exciting world of MDB Tools! In short, MDB Tools is a set of
|
|
|
|
|
programs to help you use Microsoft Access file in various settings.
|
2018-02-14 02:54:34 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
The initial goal of these tools is to be able to extract data structures and
|
|
|
|
|
data from mdb files. This goal will of course expand over time as the file
|
|
|
|
|
format becomes more well understood.
|
2018-02-07 03:47:30 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
# Components
|
2000-02-13 07:51:37 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
The major pieces of MDB Tools are:
|
2002-04-15 07:35:39 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
## libmdb
|
2000-02-13 07:51:37 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
The core library that allows access to MDB files programatically.
|
2000-02-13 07:51:37 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
## libmdbsql
|
|
|
|
|
|
|
|
|
|
Builds on libmdb to provide a SQL engine (aka Jet)
|
|
|
|
|
|
|
|
|
|
## utils
|
|
|
|
|
|
2020-08-10 03:23:38 +08:00
|
|
|
|
Provides command line utilities, including:
|
2020-08-04 03:02:20 +08:00
|
|
|
|
|
2020-08-07 00:51:45 +08:00
|
|
|
|
| Command | Description |
|
|
|
|
|
| ------- | ----------- |
|
2020-08-10 03:23:38 +08:00
|
|
|
|
| `mdb-ver` | Prints the version (JET 3 or 4) of an mdb file. |
|
|
|
|
|
| `mdb-schema` | Prints DDL for the specified table. |
|
|
|
|
|
| `mdb-export` | Export table to CSV format. |
|
|
|
|
|
| `mdb-tables` | A simple dump of table names to be used with shell scripts. |
|
|
|
|
|
| `mdb-count` | A simple count of number of rows in a table, to be used in shell scripts and ETL pipelines. |
|
|
|
|
|
| `mdb-header` | Generates a C header to be used in exporting mdb data to a C prog. |
|
|
|
|
|
| `mdb-parsecsv` | Generates a C program given a CSV file made with mdb-export. |
|
|
|
|
|
| `mdb-sql` | A simple SQL engine (also used by ODBC and gmdb). |
|
|
|
|
|
| `prcat` | Prints the catalog table from an mdb file. |
|
|
|
|
|
| `prkkd` | Dump of information about design view data given the offset to it. |
|
|
|
|
|
| `prtable` | Dump of a table definition. |
|
|
|
|
|
| `prdata` | Dump of the data given a table name. |
|
|
|
|
|
| `prole` | Dump of ole columns given a table name and sargs. |
|
|
|
|
|
| `mdb-hexdump` | (in src/extras) Simple hex dump utility that I've been using to look at mdb files. |
|
|
|
|
|
|
|
|
|
|
## odbc
|
|
|
|
|
|
|
|
|
|
An ODBC driver for use with unixODBC or iODBC driver manager. Allows one to use MDB files with PHP for example.
|
|
|
|
|
|
|
|
|
|
## gmdb2
|
|
|
|
|
|
|
|
|
|
The Gnome MDB File Viewer and debugger. Still alpha.
|
2020-08-04 03:02:20 +08:00
|
|
|
|
|
|
|
|
|
# License
|
2000-02-13 07:51:37 +08:00
|
|
|
|
|
2013-07-15 03:35:06 +08:00
|
|
|
|
Files in libmdb, libmdbsql, and libmdbodbc are licensed under LGPL and the
|
2020-08-04 03:02:20 +08:00
|
|
|
|
utilities and gui program are under the GPL, see [COPYING.LIB](./COPYING.LIB)
|
|
|
|
|
and [COPYING](./COPYING) files respectively.
|
2000-02-13 07:51:37 +08:00
|
|
|
|
|
2000-03-05 01:31:07 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
# Requirements
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
|
|
|
|
First, you must have reasonably current installations of:
|
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
* [libtool](https://www.gnu.org/software/libtool/)
|
|
|
|
|
* [automake](https://www.gnu.org/software/automake/)
|
|
|
|
|
* [autoconf](https://www.gnu.org/software/autoconf/) (version >= 2.58)
|
2015-02-21 13:51:47 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
If you want to build the SQL engine, you'll need
|
2020-08-18 19:32:15 +08:00
|
|
|
|
[bison](https://www.gnu.org/software/bison/) (version >= 3.0) or
|
2020-08-04 03:02:20 +08:00
|
|
|
|
[byacc](https://invisible-island.net/byacc/byacc.html), and
|
|
|
|
|
[flex](https://github.com/westes/flex).
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
If you want to build the ODBC driver, you'll need `unixodbc-dev` (version
|
|
|
|
|
2.2.10 or above) or [iodbc](http://www.iodbc.org/dataspace/doc/iodbc/wiki/iodbcWiki/WelcomeVisitors).
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
If you want to build man pages, you'll need
|
|
|
|
|
[txt2man](https://github.com/mvertes/txt2man).
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
If you want to generate the html version of the docbook, you'll need
|
|
|
|
|
[openjade](http://openjade.sourceforge.net) and basic dsl catalogs.
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
# Installation
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
Last version is available at https://github.com/evanmiller/mdbtools
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2017-12-18 02:23:48 +08:00
|
|
|
|
```bash
|
2020-08-07 00:51:45 +08:00
|
|
|
|
$ autoreconf -i -f -Wno-portability
|
2017-12-18 02:23:48 +08:00
|
|
|
|
```
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
|
|
|
|
If you want to build the html version of the docbook documentation, you need to
|
2020-08-04 03:02:20 +08:00
|
|
|
|
set the environment variable `DOCBOOK_DSL` to the modular dsl translation file.
|
2013-07-15 03:35:06 +08:00
|
|
|
|
For exemple, before configure, you need something like:
|
|
|
|
|
|
2017-12-18 02:23:48 +08:00
|
|
|
|
```bash
|
|
|
|
|
$ export DOCBOOK_DSL=/usr/share/sgml/docbook/stylesheet/dsssl/modular/html/docbook.dsl
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2017-12-18 02:23:48 +08:00
|
|
|
|
$ ./configure
|
|
|
|
|
```
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
|
|
|
|
OR for a complete install (requires bison, flex, and unixODBC):
|
|
|
|
|
|
2017-12-18 02:23:48 +08:00
|
|
|
|
```bash
|
|
|
|
|
$ ./configure --with-unixodbc=/usr/local
|
|
|
|
|
```
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2020-08-07 00:51:45 +08:00
|
|
|
|
By default, MDB Tools is linked against the copy of
|
|
|
|
|
[GLib](https://developer.gnome.org/glib/) returned by pkg-config. You can
|
|
|
|
|
point to a different GLib installation using the `GLIB_CFLAGS` and `GLIB_LIBS`
|
|
|
|
|
enivornment variables. Or, you can disable GLib entirely with the
|
|
|
|
|
`--disable-glib` flag, in which case MDB Tools will use an internal
|
|
|
|
|
implementation of GLib's functions.
|
|
|
|
|
|
2013-07-15 03:35:06 +08:00
|
|
|
|
configure can be passed any of the following flags to turn on other
|
2017-12-18 02:23:48 +08:00
|
|
|
|
capabilities. Note that the options `--with-unixodbc` and `--with-iodbc` are
|
2013-07-15 03:35:06 +08:00
|
|
|
|
mutually exclusive.
|
2017-12-18 02:23:48 +08:00
|
|
|
|
|
|
|
|
|
```
|
2013-07-15 03:35:06 +08:00
|
|
|
|
--with-unixodbc specifies the location of the unixODBC driver manager and
|
|
|
|
|
causes the unixODBC driver to be built.
|
|
|
|
|
--with-iodbc specifies the location of the iODBC driver manager and
|
|
|
|
|
causes the iODBC driver to be built.
|
2017-12-18 02:23:48 +08:00
|
|
|
|
```
|
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
A list of general options is available in the [INSTALL](./INSTALL) file, and
|
2017-12-18 02:23:48 +08:00
|
|
|
|
`configure --help` will give you the list of mdbtools specific options.
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2017-12-18 02:23:48 +08:00
|
|
|
|
```bash
|
|
|
|
|
$ make
|
|
|
|
|
```
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
|
|
|
|
Once MDB Tools has been compiled, libmdb.[so|a] will be in the src/libmdb
|
|
|
|
|
directory and the utility programs will be in the src/util directory.
|
|
|
|
|
|
2018-02-07 03:47:30 +08:00
|
|
|
|
You can then install (to /usr/local by default) by running the following as root:
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2018-02-07 03:47:30 +08:00
|
|
|
|
```bash
|
|
|
|
|
$ make install
|
|
|
|
|
```
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2018-02-07 03:47:30 +08:00
|
|
|
|
Some systems will also need the ld cache to be updated after installation;
|
|
|
|
|
You can do that running:
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2018-02-07 03:47:30 +08:00
|
|
|
|
```bash
|
|
|
|
|
$ ldconfig
|
|
|
|
|
```
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
# Hacking
|
2013-07-15 03:35:06 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
If you are interested in helping, read the [HACKING](./HACKING) file for a description of
|
|
|
|
|
where the code stands and what has been gleened of the file format.
|
2000-02-13 07:51:37 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
# Contact
|
2000-02-13 07:51:37 +08:00
|
|
|
|
|
2020-08-04 03:02:20 +08:00
|
|
|
|
Please send bug reports to the new github repository.
|
|
|
|
|
https://github.com/evanmiller/mdbtools/issues
|