EntityFilesystem 4.0.2

There is a newer version of this package available.
See the version list below for details.
dotnet add package EntityFilesystem --version 4.0.2                
NuGet\Install-Package EntityFilesystem -Version 4.0.2                
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="EntityFilesystem" Version="4.0.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add EntityFilesystem --version 4.0.2                
#r "nuget: EntityFilesystem, 4.0.2"                
#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.
// Install EntityFilesystem as a Cake Addin
#addin nuget:?package=EntityFilesystem&version=4.0.2

// Install EntityFilesystem as a Cake Tool
#tool nuget:?package=EntityFilesystem&version=4.0.2                

EntityFramework.Filesystem

FileBaseContext is a EntityFramework.Filesystem Provider for Net8+

Store tables in file, easy 'Serverless' file system text file serialised ef db persistance

https://learn.microsoft.com/en-us/ef/core/providers/?tabs=dotnet-core-cli

Similar projects :

FileContextCore - Offers Different serializer supported (XML, JSON, CSV, Excel) no support Net4+

https://github.com/morrisjdev/FileContextCore https://www.nuget.org/packages/FileContextCore/ Frameworks based on the idea of FileContext by DevMentor (https://github.com/pmizel/DevMentor.Context.FileContext)

FileBaseContext is a provider of Entity Framework Core 8 to store database information in files.

Powerful file based database provider for Entity Framework Core, easy 'Serverless' file system text file serialised ef db persistance

Works for

  • Unit Test - Mocking
  • Serverless db persistance, easier than Sqlite (Tables are created for one thing)
  • Works cross platform, easy offline persistant data store

Although it was built for development purposes, it works for serverless db persistance. All information is stored in files that can be added, updated, or deleted manually via file system.

It can be used with Although it was built for development purposes.

All information is stored in files that can be added, updated, or deleted manually.

Benefits

  • Easier than Sqlite, just works
  • you don't need a database server
  • rapid modeling
  • version control supported
  • supports all serializable .NET types-
  • unit tests

Download

https://www.nuget.org/packages/EntityFramework.Filesystem/

Configure Database Context

add database context to services

services.AddDbContext<ApplicationDbContext>(options => options.UseFileBaseContextDatabase("dbUser"));

or configure the database context itself


public static string DatabaseName = "my_local_db"; // Will create folder  \bin\my_local_db and tables.json files

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
	optionsBuilder.UseFileStoreDatabase("my_local_db");
	base.OnConfiguring(optionsBuilder);
}

Configure Provider

Named database
 protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    {
        optionsBuilder.UseFileBaseContextDatabase(databaseName: DatabaseName); 
    }
Custom location
optionsBuilder.UseFileBaseContextDatabase(location: "C:\Temp\userDb");

Unit testing

Since 2.1.0 the FileBaseContext injects access to the file system through System.IO.Abstractions library. It allows the use of the provider in unit tests.

If you need to use the provider in unit tests, you can change IFileSystem to MockFileSystem in OnConfiguring method in datacontext class.

private readonly MockFileSystem _fileSystem;
public DbTestContext(MockFileSystem fileSystem)
{
    _fileSystem = fileSystem;
}

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
    optionsBuilder.UseFileBaseContextDatabase(DatabaseName, null, services =>
    {
        services.AddMockFileSystem(_fileSystem);
    });
}

Please find example in the SimplePositiveTests class in the test project

New in 4.0.0

Since the 4.0.0 version the FileBaseContext supports persisting data in the CSV files. The CSV files are stored in the directory with the database name. The CSV files are named by the entity name. The first row in the CSV file is the header with the column names.

! Braking changes in 3.0.0 !

In 3.0.0 version the provider was changed to support numeric values without quotation marks.

{
    "IntProp": 42,
    "LongProperty": 420,
    "DateTime": "2023-12-26T19:28:08"
}

The led to breaking changes in the provider. If you have used the provider before, you need to manualy update the database files. The changes also affect on DateTime and DateTimeOffset values. The values are stored as string in the database. First run of the application could be slow becasuse a lot of System.Text.Json.JsonException will be provided. Performance be fixed after provider saves a database to files. While that the data will be stored in new formats. If you still have performance issues you need to manualy update the database files.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
4.0.5 75 10/31/2024
4.0.4 93 9/21/2024
4.0.3 111 9/17/2024
4.0.2 135 9/4/2024