Crates.io | oxigraph |
lib.rs | oxigraph |
version | 0.4.3 |
source | src |
created_at | 2020-08-08 12:54:56.425886 |
updated_at | 2024-11-07 18:21:48.208611 |
description | a SPARQL database and RDF toolkit |
homepage | https://oxigraph.org/ |
repository | https://github.com/oxigraph/oxigraph/tree/main/lib/oxigraph |
max_upload_size | |
id | 274351 |
size | 741,855 |
Oxigraph is a graph database library implementing the SPARQL standard.
Its goal is to provide a compliant, safe and fast on-disk graph database. It also provides a set of utility functions for reading, writing, and processing RDF files.
Oxigraph is in heavy development and SPARQL query evaluation has not been optimized yet.
Oxigraph also provides a CLI tool and a Python library based on this library.
Oxigraph implements the following specifications:
A preliminary benchmark is provided. Oxigraph internal design is described on the wiki.
The main entry point of Oxigraph is the Store
struct:
use oxigraph::store::Store;
use oxigraph::model::*;
use oxigraph::sparql::QueryResults;
let store = Store::new().unwrap();
// insertion
let ex = NamedNode::new("http://example.com").unwrap();
let quad = Quad::new(ex.clone(), ex.clone(), ex.clone(), GraphName::DefaultGraph);
store.insert(&quad).unwrap();
// quad filter
let results = store.quads_for_pattern(Some(ex.as_ref().into()), None, None, None).collect::<Result<Vec<Quad>,_>>().unwrap();
assert_eq!(vec![quad], results);
// SPARQL query
if let QueryResults::Solutions(mut solutions) = store.query("SELECT ?s WHERE { ?s ?p ?o }").unwrap() {
assert_eq!(solutions.next().unwrap().unwrap().get("s"), Some(&ex.into()));
}
It is based on these crates that can be used separately:
oxrdf
, datastructures encoding RDF basic concepts (the oxigraph::model
module).oxrdfio
, a unified parser and serializer API for RDF formats (the oxigraph::io
module). It itself relies on:
spargebra
, a SPARQL parser.sparesults
, parsers and serializers for SPARQL result formats (the oxigraph::sparql::results
module).sparopt
, a SPARQL optimizer.oxsdatatypes
, an implementation of some XML Schema datatypes.To build the library locally, don't forget to clone the submodules using git clone --recursive https://github.com/oxigraph/oxigraph.git
to clone the repository including submodules or git submodule update --init
to add submodules to the already cloned repository.
It is possible to disable the RocksDB storage backend to only use the in-memory fallback by disabling the rocksdb
default feature:
oxigraph = { version = "*", default-features = false }
This is the default behavior when compiling Oxigraph to WASM.
This project is licensed under either of
<http://www.apache.org/licenses/LICENSE-2.0>
)<http://opensource.org/licenses/MIT>
)at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Oxigraph by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.