JetDatabaseReader 1.0.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package JetDatabaseReader --version 1.0.0
NuGet\Install-Package JetDatabaseReader -Version 1.0.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="JetDatabaseReader" Version="1.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="JetDatabaseReader" Version="1.0.0" />
<PackageReference Include="JetDatabaseReader" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add JetDatabaseReader --version 1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: JetDatabaseReader, 1.0.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package JetDatabaseReader@1.0.0
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=JetDatabaseReader&version=1.0.0
#tool nuget:?package=JetDatabaseReader&version=1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
JetDatabaseReader
Pure-managed .NET library for reading Microsoft Access JET databases without requiring OleDB, ODBC, or ACE drivers.
Features
- ✅ No Dependencies - Pure C# implementation, no native drivers required
- ✅ Jet3 & Jet4+ - Supports Access 97 (.mdb) through Access 2019 (.mdb/.accdb)
- ✅ All Data Types - Text, Integer, Date, GUID, Currency, MEMO, OLE Object
- ✅ Streaming API - Process millions of rows without out-of-memory errors
- ✅ Page Caching - 256-page LRU cache for 50%+ performance boost
- ✅ Progress Reporting -
IProgress<int>callbacks for long operations - ✅ Multi-Language - Auto-detects code page (Cyrillic, Japanese, etc.)
- ✅ OLE Objects - Auto-detects embedded images, PDFs, Office docs
Installation
dotnet add package JetDatabaseReader
Or via Package Manager Console:
Install-Package JetDatabaseReader
Quick Start
using JetDatabaseReader;
// Open database
using (var reader = new JetDatabaseReader("database.mdb"))
{
// List all tables
var tables = reader.ListTables();
Console.WriteLine($"Found {tables.Count} tables");
// Read a table (first 100 rows)
var (headers, rows, schema) = reader.ReadTable("MyTable", maxRows: 100);
foreach (var row in rows)
{
Console.WriteLine(string.Join(", ", row));
}
}
Usage Examples
Stream Large Tables
using (var reader = new JetDatabaseReader("large.mdb"))
{
var progress = new Progress<int>(count =>
Console.WriteLine($"Processed {count} rows"));
foreach (var row in reader.StreamRows("BigTable", progress))
{
// Process one row at a time - no memory issues
ProcessRow(row);
}
}
Read as DataTable
using (var reader = new JetDatabaseReader("data.mdb"))
{
DataTable dt = reader.ReadTableAsDataTable("Customers");
// Bind to DataGridView, export to CSV, etc.
dataGridView1.DataSource = dt;
}
Get Table Statistics
using (var reader = new JetDatabaseReader("db.mdb"))
{
var stats = reader.GetTableStats();
foreach (var (name, rowCount, columnCount) in stats)
{
Console.WriteLine($"{name}: {rowCount} rows, {columnCount} columns");
}
}
Enable Performance Features
var reader = new JetDatabaseReader("database.mdb")
{
PageCacheSize = 512, // Increase cache (default: 256)
ParallelPageReadsEnabled = true, // Parallel I/O (default: false)
DiagnosticsEnabled = true // Debug output (default: false)
};
Limitations
- ❌ Encrypted databases - Remove password in Access first (File > Info > Encrypt with Password)
- ❌ Attachment fields (Type 0x11) - Rare, added in Access 2007
- ❌ Linked tables - Only local tables are returned
- ❌ Write operations - Read-only library
Compatibility
- .NET Standard 2.0 - Compatible with:
- .NET Framework 4.6.1+
- .NET Core 2.0+
- .NET 5/6/7/8+
- Xamarin, Unity, UWP
How It Works
Based on the mdbtools format specification, this library directly parses JET database pages without requiring Microsoft drivers. It handles:
- Database header parsing (Jet3/Jet4 detection)
- MSysObjects catalog scanning
- TDEF (table definition) page chains
- Data page traversal
- LVAL (long value) chains for MEMO/OLE fields
- Compressed Unicode text (Jet4)
- Code page detection for non-Western text
Contributing
Contributions are welcome! Please open an issue or submit a pull request.
License
MIT License - see LICENSE for details
Acknowledgments
Format specification based on mdbtools by Brian Bruns and contributors.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.