Ax.Fw.Storage 14.1.208

There is a newer version of this package available.
See the version list below for details.
dotnet add package Ax.Fw.Storage --version 14.1.208
                    
NuGet\Install-Package Ax.Fw.Storage -Version 14.1.208
                    
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.1.208" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Ax.Fw.Storage" Version="14.1.208" />
                    
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.1.208
                    
#r "nuget: Ax.Fw.Storage, 14.1.208"
                    
#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.
#addin nuget:?package=Ax.Fw.Storage&version=14.1.208
                    
Install as a Cake Addin
#tool nuget:?package=Ax.Fw.Storage&version=14.1.208
                    
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.256 126 6/19/2025
14.5.255 122 6/19/2025
14.5.254 274 6/12/2025
14.5.252 141 5/11/2025
14.5.251 147 5/8/2025
14.5.250 146 5/8/2025
14.5.249 143 5/8/2025
14.5.248 145 5/8/2025
14.5.247 187 2/8/2025
14.5.246 106 2/8/2025
14.5.245 113 2/7/2025
14.5.244 105 1/29/2025
14.5.242 100 1/29/2025
14.5.241 100 1/29/2025
14.4.240 194 11/2/2024
14.4.239 193 10/18/2024
14.4.237 127 9/19/2024
14.4.236 173 8/11/2024
14.3.235 143 8/10/2024
14.3.234 104 8/5/2024
14.3.233 112 7/29/2024
14.3.232 122 7/23/2024
14.3.231 120 7/22/2024
14.3.230 137 7/17/2024
14.3.229 113 7/17/2024
14.3.228 121 7/11/2024
14.3.227 127 7/10/2024
14.3.226 154 7/3/2024
14.3.225 143 6/14/2024
14.3.224 112 6/7/2024
14.3.223 132 6/6/2024
14.3.222 137 5/17/2024
14.3.221 165 4/12/2024
14.2.219 134 4/11/2024
14.2.218 129 4/10/2024
14.2.217 225 3/29/2024
14.2.216 145 3/27/2024
14.2.215 142 3/22/2024
14.1.212 146 3/11/2024
14.1.211 134 3/11/2024
14.1.210 133 3/6/2024
14.1.208 146 3/6/2024
14.1.206 146 3/2/2024
14.1.205 149 3/1/2024
14.0.204 154 2/19/2024
14.0.203 136 2/16/2024
14.0.201 152 2/15/2024
13.0.200 161 2/10/2024
13.0.199 142 2/10/2024
13.0.198 141 2/10/2024
13.0.197 321 12/10/2023
13.0.196 150 12/10/2023
13.0.195 147 12/9/2023
13.0.194 127 12/6/2023
13.0.192 140 12/5/2023
13.0.191 173 11/26/2023
13.0.189 145 11/24/2023
13.0.186 140 11/23/2023
13.0.185 148 11/22/2023
13.0.182 146 11/18/2023
13.0.181 177 11/14/2023
13.0.180 340 11/12/2023
13.0.179 138 11/10/2023
12.1.178 165 10/25/2023
12.1.177 158 10/24/2023
12.1.176 155 10/21/2023
12.1.175 161 10/21/2023
12.1.173 153 10/16/2023
12.1.172 179 10/15/2023
12.1.171 154 10/15/2023
12.1.170 148 10/15/2023
12.1.168 169 10/15/2023
12.1.167 130 10/14/2023
12.1.166 196 9/7/2023
12.1.165 223 8/28/2023
12.1.164 259 8/15/2023
12.1.163 217 8/14/2023
12.1.162 188 8/14/2023
12.1.161 228 6/20/2023
12.1.160 232 6/10/2023
12.1.158 204 5/31/2023
12.1.157 200 5/22/2023
12.1.7 197 5/21/2023
12.1.0 193 5/19/2023
12.0.21 202 5/18/2023
12.0.20 182 5/18/2023
12.0.19 204 5/10/2023
12.0.18 183 5/4/2023
12.0.17 212 5/3/2023
12.0.16 227 4/30/2023
12.0.15 220 4/30/2023
12.0.13 226 4/27/2023
12.0.12 232 4/27/2023
12.0.10 294 4/15/2023
12.0.9 281 4/6/2023
12.0.8 282 3/27/2023
12.0.7 275 3/27/2023
12.0.3 269 3/22/2023
12.0.2 271 3/22/2023
12.0.1 303 3/1/2023
12.0.0 341 2/11/2023
11.1.10 322 2/11/2023
11.1.9 326 2/10/2023
11.1.8 324 2/6/2023
11.1.7 325 2/5/2023
11.1.6 334 2/4/2023
11.1.5 334 2/4/2023
11.1.4 367 12/30/2022
11.1.3 403 12/26/2022
11.1.2 348 12/26/2022
11.1.1 365 12/25/2022
11.0.0 357 12/24/2022
1.0.0 383 12/24/2022