Hiperspace.Rocks
2.1.3
See the version list below for details.
dotnet add package Hiperspace.Rocks --version 2.1.3
NuGet\Install-Package Hiperspace.Rocks -Version 2.1.3
<PackageReference Include="Hiperspace.Rocks" Version="2.1.3" />
<PackageVersion Include="Hiperspace.Rocks" Version="2.1.3" />
<PackageReference Include="Hiperspace.Rocks" />
paket add Hiperspace.Rocks --version 2.1.3
#r "nuget: Hiperspace.Rocks, 2.1.3"
#addin nuget:?package=Hiperspace.Rocks&version=2.1.3
#tool nuget:?package=Hiperspace.Rocks&version=2.1.3
Hiperspace.Rocks
RocksDB is a remarkable technology, originally developed by Google (LevelDB) and optimized by Facebook for
absolutely lowest possible latency writing to SSD devices.
RocksDB used Log-structured-Merge (LSM) to stream updates while maintaining fast key access.
It is used both as a key/value database, and also as a driver for relational-databases, message-stores,
blockchain and various analytical services. The use of LSM optimizes performance and life of SSD devices.
Hiperspace.Rocks uses RockDB to store elements in durable SSD memory
Product | Versions 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 is compatible. 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. |
-
net8.0
- Hiperspace (>= 2.1.3)
- Microsoft.Bcl.HashCode (>= 6.0.0)
- protobuf-net.Core (>= 3.2.46)
- RocksDB (>= 9.10.0.55496)
- System.Numerics.Tensors (>= 9.0.2)
-
net9.0
- Hiperspace (>= 2.1.3)
- Microsoft.Bcl.HashCode (>= 6.0.0)
- protobuf-net.Core (>= 3.2.46)
- RocksDB (>= 9.10.0.55496)
- System.Numerics.Tensors (>= 9.0.2)
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 |
---|---|---|
2.4.0 | 105 | 7/10/2025 |
2.3.8 | 133 | 7/1/2025 |
2.3.7 | 137 | 6/18/2025 |
2.3.3 | 137 | 6/5/2025 |
2.2.2 | 154 | 5/5/2025 |
2.2.1 | 218 | 4/14/2025 |
2.2.0 | 104 | 3/29/2025 |
2.1.3 | 213 | 3/5/2025 |
2.1.1 | 117 | 2/15/2025 |
2.1.0 | 123 | 1/24/2025 |
2.0.0 | 95 | 1/14/2025 |
1.3.9 | 117 | 11/15/2024 |
1.3.0 | 127 | 10/5/2024 |
1.2.31 | 169 | 9/15/2024 |
1.2.28 | 131 | 9/7/2024 |
1.2.26 | 127 | 9/1/2024 |
1.2.8 | 135 | 7/15/2024 |
1.2.4 | 143 | 7/4/2024 |
1.2.0 | 138 | 5/30/2024 |
1.0.34 | 146 | 3/14/2024 |
1.0.28 | 151 | 2/26/2024 |
1.0.27 | 149 | 2/16/2024 |
1.0.24 | 184 | 1/11/2024 |
1.0.23 | 173 | 1/1/2024 |
1.0.1 | 171 | 11/18/2023 |
# Overview
This release is primarily concerned with performance when used in a server context the volume if data is huge and accessed via `Hiperspace.DB` and many CPU-cores are available.
Performance is addressed with greater parallelism (graph `Node` and `Edge` queries already execute in parallel) and server-side filtering with using SQL queries.
## Parallelism
`PartitionSpace` and `GenerationSpace` have been updated to search each of the child spaces in parallel and collate results to return to a calling space. For very large hiperspaces `PartitionSpace` enables `Hiperspace.DB` to match the performance of direct/local hiperspaces by executing access in parallel. Hiperspace uses versioning to avoid transaction contention when multiple sessions are accessing a Space, as historical versions of a `GenerationSpace` never ned to be updated they are opened with read-only option, which obviates the need for rockshare to mediate access to the underlying files.
## SQL Queries
Hiperspace is optimized for key or index access to efficiently search hiperspace for elements that match key or key-part criteria.
For the model `entity Customer ( Id : Int64 ) { Name : String, ...};`, a client query `from c in space.Customers where c.Id == 42' is translated into 'space.Customers.Find (new Customer { Id = 42} )` which in turn is translated into `CustomerKeyPath.Get (42)`, which directly fetches the customer from Hiperspace.
For the model
```
entity Customer ( Id : Int64 ) { Name : String, ... [Accounts : Account ].
segment Account ( Id : Int64 ) { Title : String, ...};
```
A query `from as in space.CustomerAccounts where owner.Id == 42' is translated into 'space.CustomerAccounts.Find (new Account { owner = new Customer { Id = 42} })` which in turn is translated into `CustomerAccountKeyPath.Find (42)` retrieving all Accounts that are owned by Customer 42.
For the model
```
entity Customer ( Id : Int64 ) { Name : String, ...} [ Accounts : Account ( Customer = this ) ];
entity Account ( Id : Int64 ) { Title : String, Customer : Customer, ...};
```
A query `from as in space.Accounts where Customer.Id == 42' is translated into 'space.Accounts.Find (new Account { Customer = new Customer { Id = 42} })` which in turn is translated into `AccountCustonerIndex Path.Find (42)` retrieving all Accounts that have a Customer 42, because the Customer extension `Accounts : Account ( Customer = this )` causes an index to be created on Account.
**If** the extension `Accounts : Account ( Customer = this )` is omitted, the Account `SetSpace` is scanned (with a residual condition Customer.KeyType.Id of 42), but if the query is `from as in space.Accounts where Customer.Id < 42' the criteria is evaluated once the results have been returned - potentially a very large set.
### Query
The `Query` function allows 'space.Accounts.Query ("SELECT Account.* FROM Accounts WHERE Accounts.Customer.Id < 42") to be used to send the query to a `Hiperspace.DB` server where the results will be filtered before return to the client.