File: plugin_stores.rst

package info (click to toggle)
rdflib 7.1.1-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 77,580 kB
  • sloc: python: 58,671; sh: 153; makefile: 88; ruby: 74; xml: 45
file content (70 lines) | stat: -rw-r--r-- 3,268 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
.. _plugin_stores: Plugin stores

=============
Plugin stores
=============
 
Built In
--------

The following Stores are contained within the rdflib core package:

================= ============================================================
Name              Class                                                       
================= ============================================================
Auditable         :class:`~rdflib.plugins.stores.auditable.AuditableStore`
Concurrent        :class:`~rdflib.plugins.stores.concurrent.ConcurrentStore`
SimpleMemory      :class:`~rdflib.plugins.stores.memory.SimpleMemory`
Memory            :class:`~rdflib.plugins.stores.memory.Memory`
SPARQLStore       :class:`~rdflib.plugins.stores.sparqlstore.SPARQLStore`
SPARQLUpdateStore :class:`~rdflib.plugins.stores.sparqlstore.SPARQLUpdateStore`
BerkeleyDB        :class:`~rdflib.plugins.stores.berkeleydb.BerkeleyDB`
default           :class:`~rdflib.plugins.stores.memory.Memory`
================= ============================================================

External
--------

The following Stores are defined externally to rdflib's core package, so look to their documentation elsewhere for 
specific details of use.

================= ==================================================== =============================================================================================
Name              Repository                                           Notes
================= ==================================================== =============================================================================================
SQLAlchemy        `<https://github.com/RDFLib/rdflib-sqlalchemy>`_     An SQLAlchemy-backed, formula-aware RDFLib Store. Tested dialects are: SQLite, MySQL & PostgreSQL
leveldb           `<https://github.com/RDFLib/rdflib-leveldb>`_        An adaptation of RDFLib BerkeleyDB Store’s key-value approach, using LevelDB as a back-end
Kyoto Cabinet     `<https://github.com/RDFLib/rdflib-kyotocabinet>`_   An adaptation of RDFLib BerkeleyDB Store’s key-value approach, using Kyoto Cabinet as a back-end
HDT               `<https://github.com/RDFLib/rdflib-hdt>`_            A Store back-end for rdflib to allow for reading and querying `HDT <https://www.rdfhdt.org/>`_ documents
Oxigraph          `<https://github.com/oxigraph/oxrdflib>`_            Works with the `Pyoxigraph <https://oxigraph.org/pyoxigraph>`_ Python graph database library
================= ==================================================== =============================================================================================

*If you have, or know of a Store implementation and would like it listed here, please submit a Pull Request!*

Use
---

You can use these stores like this:

.. code-block:: python

    from rdflib import Graph
    
    # use the default memory Store
    graph = Graph()
    
    # use the BerkeleyDB Store
    graph = Graph(store="BerkeleyDB")


In some cases, you must explicitly *open* and *close* a store, for example:

.. code-block:: python

    from rdflib import Graph
    
    # use the BerkeleyDB Store
    graph = Graph(store="BerkeleyDB")
    graph.open("/some/folder/location")
    # do things ...
    graph.close()