Ax.Fw.Storage 14.5.269

dotnet add package Ax.Fw.Storage --version 14.5.269
                    
NuGet\Install-Package Ax.Fw.Storage -Version 14.5.269
                    
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="14.5.269" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Ax.Fw.Storage" Version="14.5.269" />
                    
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 14.5.269
                    
#r "nuget: Ax.Fw.Storage, 14.5.269"
                    
#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@14.5.269
                    
#: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=14.5.269
                    
Install as a Cake Addin
#tool nuget:?package=Ax.Fw.Storage&version=14.5.269
                    
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 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.  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.269 36 1/17/2026
14.5.268 34 1/17/2026
14.5.266 33 1/16/2026
14.5.263 93 12/31/2025
14.5.262 179 12/24/2025
14.5.261 178 12/24/2025
14.5.260 170 12/23/2025
14.5.258 209 9/6/2025
14.5.257 455 8/6/2025
14.5.256 241 6/19/2025
14.5.255 195 6/19/2025
14.5.254 354 6/12/2025
14.5.252 235 5/11/2025
14.5.251 217 5/8/2025
14.5.250 220 5/8/2025
14.5.249 220 5/8/2025
14.5.248 222 5/8/2025
14.5.247 265 2/8/2025
14.5.246 186 2/8/2025
14.5.245 187 2/7/2025
14.5.244 178 1/29/2025
14.5.242 174 1/29/2025
14.5.241 181 1/29/2025
14.4.240 266 11/2/2024
14.4.239 266 10/18/2024
14.4.237 198 9/19/2024
14.4.236 244 8/11/2024
14.3.235 221 8/10/2024
14.3.234 179 8/5/2024
14.3.233 184 7/29/2024
14.3.232 193 7/23/2024
14.3.231 198 7/22/2024
14.3.230 209 7/17/2024
14.3.229 183 7/17/2024
14.3.228 198 7/11/2024
14.3.227 203 7/10/2024
14.3.226 225 7/3/2024
14.3.225 219 6/14/2024
14.3.224 182 6/7/2024
14.3.223 206 6/6/2024
14.3.222 219 5/17/2024
14.3.221 242 4/12/2024
14.2.219 212 4/11/2024
14.2.218 200 4/10/2024
14.2.217 284 3/29/2024
14.2.216 230 3/27/2024
14.2.215 219 3/22/2024
14.1.212 216 3/11/2024
14.1.211 199 3/11/2024
14.1.210 213 3/6/2024
14.1.208 216 3/6/2024
14.1.206 249 3/2/2024
14.1.205 230 3/1/2024
14.0.204 229 2/19/2024
14.0.203 219 2/16/2024
14.0.201 243 2/15/2024
13.0.200 236 2/10/2024
13.0.199 215 2/10/2024
13.0.198 215 2/10/2024
13.0.197 395 12/10/2023
13.0.196 218 12/10/2023
13.0.195 222 12/9/2023
13.0.194 174 12/6/2023
13.0.192 177 12/5/2023
13.0.191 236 11/26/2023
13.0.189 179 11/24/2023
13.0.186 195 11/23/2023
13.0.185 199 11/22/2023
13.0.182 194 11/18/2023
13.0.181 238 11/14/2023
13.0.180 1,028 11/12/2023
13.0.179 176 11/10/2023
12.1.178 211 10/25/2023
12.1.177 203 10/24/2023
12.1.176 199 10/21/2023
12.1.175 204 10/21/2023
12.1.173 204 10/16/2023
12.1.172 233 10/15/2023
12.1.171 198 10/15/2023
12.1.170 207 10/15/2023
12.1.168 212 10/15/2023
12.1.167 182 10/14/2023
12.1.166 264 9/7/2023
12.1.165 279 8/28/2023
12.1.164 322 8/15/2023
12.1.163 278 8/14/2023
12.1.162 252 8/14/2023
12.1.161 306 6/20/2023
12.1.160 314 6/10/2023
12.1.158 287 5/31/2023
12.1.157 277 5/22/2023
12.1.7 286 5/21/2023
12.1.0 278 5/19/2023
12.0.21 295 5/18/2023
12.0.20 272 5/18/2023
12.0.19 292 5/10/2023
12.0.18 273 5/4/2023
12.0.17 296 5/3/2023
12.0.16 310 4/30/2023
12.0.15 306 4/30/2023
12.0.13 318 4/27/2023
12.0.12 321 4/27/2023
12.0.10 370 4/15/2023
12.0.9 372 4/6/2023
12.0.8 367 3/27/2023
12.0.7 366 3/27/2023
12.0.3 367 3/22/2023
12.0.2 362 3/22/2023
12.0.1 398 3/1/2023
12.0.0 432 2/11/2023
11.1.10 418 2/11/2023
11.1.9 413 2/10/2023
11.1.8 410 2/6/2023
11.1.7 413 2/5/2023
11.1.6 424 2/4/2023
11.1.5 421 2/4/2023
11.1.4 457 12/30/2022
11.1.3 491 12/26/2022
11.1.2 432 12/26/2022
11.1.1 453 12/25/2022
11.0.0 447 12/24/2022
1.0.0 471 12/24/2022