Ax.Fw.Storage 12.1.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Ax.Fw.Storage --version 12.1.0
                    
NuGet\Install-Package Ax.Fw.Storage -Version 12.1.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="Ax.Fw.Storage" Version="12.1.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Ax.Fw.Storage" Version="12.1.0" />
                    
Directory.Packages.props
<PackageReference Include="Ax.Fw.Storage" />
                    
Project file
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 Ax.Fw.Storage --version 12.1.0
                    
#r "nuget: Ax.Fw.Storage, 12.1.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 Ax.Fw.Storage@12.1.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=Ax.Fw.Storage&version=12.1.0
                    
Install as a Cake Addin
#tool nuget:?package=Ax.Fw.Storage&version=12.1.0
                    
Install as a Cake Tool

Ax.Fw.Storage

Simple document database; based on SQLite

Why?

I just wanted to create an instance of class and be able to write to database, read from database, enumerate elements in database by key without thinking about "this database's BSON don't support ImmutableDictionary, meh", "that database doesn't support numeric keys, meh", "ah, I can't search for values of integer column using unsigned integer variable, meh" and so on. Why not "key-value" storage? I also wanted to filter my objects by last changed time. That's it. This document storage engine is not as fast as more "strongly-typed" databases (I think it's 1.1 - 1.5x slower in some scenarios), but it is reliable as any SQLite database.

Usage example:

// we need CancellationToken
var ct = default(CancellationToken);

// path to database file
var dbFile = "/home/user/data.db"

try
{
    // create database or open existing
    using var storage = new SqliteDocumentStorage(dbFile);

    // create document; pair 'namespace - key' is unique; any json serializable data can be stored
    var doc = await storage.WriteDocumentAsync(_namespace: "default", _key: "test-key", _data: "test-data-0", ct);

    // retrieve data
    var readDoc = await storage.ReadDocumentAsync(_namespace: "default", _key: "test-key", ct);

    Assert.Equal("test-data-0", readDoc?.Data.ToObject<string>());

    // there are also 'simple' documents; 
    // namespace of simple documents is automatically determined by data type or by `SimpleDocumentAttribute`
    var simpleDoc = await storage.WriteSimpleDocumentAsync(_entryId: 123, _data: "test_data", ct);

    var readSimpleDoc = await storage.ReadSimpleDocumentAsync<string>(_entryId: 123, ct);

    Assert.Equal("test_data", readSimpleDoc?.Data);

    // you also can attach in-memory cache to document storage
    // cache makes read operations significantly faster
    using var cachedStorage = storage.WithCache(_maxValuesCached: 1000, _cacheTtl: TimeSpan.FromSeconds(60));

    // you also can attach retention rules to document storage
    // documents older than certain age will be automatically deleted
    using var storageWithRules = storage
      .WithRetentionRules(TimeSpan.FromHours(1), TimeSpan.FromHours(1), TimeSpan.FromMinutes(10));
}
finally
{
    new FileInfo(dbFile).TryDelete();
}
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  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. 
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
14.5.258 180 9/6/2025
14.5.257 419 8/6/2025
14.5.256 213 6/19/2025
14.5.255 173 6/19/2025
14.5.254 333 6/12/2025
14.5.252 202 5/11/2025
14.5.251 198 5/8/2025
14.5.250 201 5/8/2025
14.5.249 199 5/8/2025
14.5.248 202 5/8/2025
14.5.247 242 2/8/2025
14.5.246 159 2/8/2025
14.5.245 167 2/7/2025
14.5.244 156 1/29/2025
14.5.242 154 1/29/2025
14.5.241 160 1/29/2025
14.4.240 248 11/2/2024
14.4.239 244 10/18/2024
14.4.237 178 9/19/2024
14.4.236 222 8/11/2024
14.3.235 195 8/10/2024
14.3.234 158 8/5/2024
14.3.233 165 7/29/2024
14.3.232 175 7/23/2024
14.3.231 171 7/22/2024
14.3.230 190 7/17/2024
14.3.229 164 7/17/2024
14.3.228 174 7/11/2024
14.3.227 184 7/10/2024
14.3.226 203 7/3/2024
14.3.225 195 6/14/2024
14.3.224 163 6/7/2024
14.3.223 187 6/6/2024
14.3.222 190 5/17/2024
14.3.221 223 4/12/2024
14.2.219 191 4/11/2024
14.2.218 183 4/10/2024
14.2.217 266 3/29/2024
14.2.216 198 3/27/2024
14.2.215 195 3/22/2024
14.1.212 193 3/11/2024
14.1.211 180 3/11/2024
14.1.210 188 3/6/2024
14.1.208 189 3/6/2024
14.1.206 230 3/2/2024
14.1.205 202 3/1/2024
14.0.204 207 2/19/2024
14.0.203 188 2/16/2024
14.0.201 208 2/15/2024
13.0.200 218 2/10/2024
13.0.199 197 2/10/2024
13.0.198 197 2/10/2024
13.0.197 374 12/10/2023
13.0.196 201 12/10/2023
13.0.195 199 12/9/2023
13.0.194 157 12/6/2023
13.0.192 162 12/5/2023
13.0.191 213 11/26/2023
13.0.189 166 11/24/2023
13.0.186 175 11/23/2023
13.0.185 180 11/22/2023
13.0.182 181 11/18/2023
13.0.181 212 11/14/2023
13.0.180 947 11/12/2023
13.0.179 159 11/10/2023
12.1.178 192 10/25/2023
12.1.177 188 10/24/2023
12.1.176 184 10/21/2023
12.1.175 188 10/21/2023
12.1.173 193 10/16/2023
12.1.172 217 10/15/2023
12.1.171 183 10/15/2023
12.1.170 190 10/15/2023
12.1.168 197 10/15/2023
12.1.167 169 10/14/2023
12.1.166 247 9/7/2023
12.1.165 263 8/28/2023
12.1.164 303 8/15/2023
12.1.163 260 8/14/2023
12.1.162 241 8/14/2023
12.1.161 288 6/20/2023
12.1.160 293 6/10/2023
12.1.158 266 5/31/2023
12.1.157 254 5/22/2023
12.1.7 264 5/21/2023
12.1.0 259 5/19/2023
12.0.21 271 5/18/2023
12.0.20 249 5/18/2023
12.0.19 272 5/10/2023
12.0.18 251 5/4/2023
12.0.17 270 5/3/2023
12.0.16 293 4/30/2023
12.0.15 284 4/30/2023
12.0.13 290 4/27/2023
12.0.12 302 4/27/2023
12.0.10 348 4/15/2023
12.0.9 349 4/6/2023
12.0.8 347 3/27/2023
12.0.7 340 3/27/2023
12.0.3 339 3/22/2023
12.0.2 336 3/22/2023
12.0.1 374 3/1/2023
12.0.0 406 2/11/2023
11.1.10 395 2/11/2023
11.1.9 396 2/10/2023
11.1.8 384 2/6/2023
11.1.7 393 2/5/2023
11.1.6 399 2/4/2023
11.1.5 401 2/4/2023
11.1.4 434 12/30/2022
11.1.3 470 12/26/2022
11.1.2 406 12/26/2022
11.1.1 432 12/25/2022
11.0.0 423 12/24/2022
1.0.0 451 12/24/2022