flutter_local_db 1.0.0 copy "flutter_local_db: ^1.0.0" to clipboard
flutter_local_db: ^1.0.0 copied to clipboard

A high-performance cross-platform local database for Dart. Native platforms use Rust+LMDB via FFI, optimized for both Dart APIs and Flutter apps.

flutter_local_db #

A high-performance cross-platform local database for Dart and Flutter applications using Rust + LMDB via FFI.

flutter_local_db

Features #

  • 🚀 High-performance: LMDB backend with Rust implementation
  • 🦀 Rust-powered: Memory-safe native performance
  • 📱 Cross-platform: Android, iOS, macOS, Linux, Windows
  • 💾 Simple API: Key-value interface with CRUD operations
  • 🛡️ Type-safe: Result-based error handling
  • Easy to use: Single file, zero configuration

Installation #

Add to your pubspec.yaml:

dependencies:
  flutter_local_db: ^1.0.0

Usage #

import 'package:flutter_local_db/flutter_local_db.dart';

void main() async {
  // Initialize the database
  await LocalDB.init('my_database');
  
  // Create a record
  final result = await LocalDB.Post('user_1', {
    'name': 'John Doe',
    'email': 'john@example.com',
    'age': 30
  });
  
  result.when(
    ok: (model) => print('Created: ${model.id}'),
    err: (error) => print('Error: $error'),
  );
  
  // Get a record
  final getResult = await LocalDB.GetById('user_1');
  final user = getResult.unwrapOr(null);
  print('User: $user');
  
  // Update a record
  await LocalDB.Put('user_1', {
    'name': 'Jane Doe',
    'email': 'jane@example.com',
    'age': 25
  });
  
  // Get all records
  final allResult = await LocalDB.GetAll();
  allResult.when(
    ok: (models) => print('Total records: ${models.length}'),
    err: (error) => print('Error: $error'),
  );
  
  // Delete a record
  await LocalDB.Delete('user_1');
  
  // Clear all data
  await LocalDB.ClearData();
  
  // Close database (optional)
  await LocalDB.close();
}

Platform Setup #

This package uses FFI to load native Rust libraries. The required binaries are included.

Android #

The Flutter plugin automatically includes the native libraries for all architectures. No additional setup required.

iOS #

The iOS plugin includes the static library via Cocoapods. No additional setup required.

Desktop #

Desktop platforms (macOS, Linux, Windows) automatically include the native libraries via their respective build systems. No additional setup required.

API Reference #

Result Type #

All database operations return LocalDbResult<T, E> for type-safe error handling:

result.when(
  ok: (value) => handleSuccess(value),
  err: (error) => handleError(error),
);

// Or use convenience methods
final value = result.unwrapOr(defaultValue);
final maybeValue = result.okOrNull;

Error Handling #

Errors are typed for better handling:

result.when(
  ok: (model) => print('Success: $model'),
  err: (error) {
    switch (error.type) {
      case LocalDbErrorType.notFound:
        print('Record not found');
        break;
      case LocalDbErrorType.validation:
        print('Invalid key: ${error.message}');
        break;
      case LocalDbErrorType.database:
        print('Database error: ${error.message}');
        break;
    }
  },
);

Performance #

  • Fast: Direct FFI calls to optimized Rust code
  • Memory efficient: LMDB memory-mapped storage
  • Minimal overhead: Single file, no complex abstractions
  • Production ready: Used in multiple production applications

Limitations #

  • Data must be JSON-serializable
  • IDs must follow the format requirements
  • Platform-specific limitations may apply
  • Currently no support for complex queries or indexing
  • No automatic migration system
  • Database name is standardized (no custom naming allowed)

Contributing #

Contributions are welcome! The project uses a dual-language architecture:

  • Flutter/Dart for the high-level API and FFI bridge
  • Rust for the core database operations

Please ensure you have both Rust and Flutter development environments set up before contributing.

License #

MIT License - see LICENSE

Author #

Made with ❤️ by JhonaCode

10
likes
160
points
389
downloads

Publisher

verified publisherjhonacode.com

Weekly Downloads

A high-performance cross-platform local database for Dart. Native platforms use Rust+LMDB via FFI, optimized for both Dart APIs and Flutter apps.

Repository (GitHub)

Topics

#nosql #ffi #rust #storage #lmdb

Documentation

API reference

License

MIT (license)

Dependencies

ffi, logger_rs, path, path_provider

More

Packages that depend on flutter_local_db