ZODB
Développé par | Zope Corporation |
---|---|
Dernière version | 6.0 ()[1] |
Dépôt | github.com/zopefoundation/ZODB |
Écrit en | Python (langage) |
Environnement | Multiplate-forme |
Formats lus | Fichier d’export Zope (d) et ZODB File Storage (2.1) (d) |
Formats écrits | Fichier d’export Zope (d) et ZODB File Storage (2.1) (d) |
Type | Base de données orientée objet |
Licences | Zope Public License |
Site web | https://zodb-docs.readthedocs.io/ |
La ZODB (Zope Object DataBase) est la base de données orientée objet du serveur d'applications Zope. Bien que Zope l'utilise comme système de fichiers, elle est néanmoins utilisable indépendamment de ce dernier pour stocker des objets Python par exemple.
À la différence d'une base de données relationnelle, une base de données orientée objet est hiérarchique, autrement dit, il s'agit d'une arborescence comme le système de fichiers d'un ordinateur :
root / \ objet A objet B
Il est possible d'utiliser des relations en donnant un identifiant aux objets qui en ont besoin et en gérant ça comme sur une base de données relationnelle avec un identifiant qui s'auto-incrémente à la création d'un objet.
En pratique
[modifier | modifier le code]ZEO (Zope Entreprise Objects) sert à donner accès concurrentiel à la ZODB sur le réseau.
- Pour installer la ZODB et ZEO avec setuptools : easy_install zodb3
- Pour lancer un serveur ZEO :
$ runzeo -a localhost:8080 -f /home/user/Data.fs
- Puis pour configurer un client ZEO, créer un fichier zeo.conf :
<zodb> <zeoclient> server localhost:8080 </zeoclient> </zodb>
- Ensuite, dans un script Python :
import ZODB.config, transaction
db = ZODB.config.databaseFromURL('/home/user/zeo.conf') conn = db.open() root = conn.root()
#root est le dictionnaire racine qui contient tous les objets de la base
root['variable'] = 'mon objet'
transaction.commit() # enregistre les changements dans la ZODB
Il est conseillé d'utiliser des objets BTrees fournis avec la ZODB, un objet BTree est conteneur, un nœud de l'arborescence, un peu comme un dictionnaire ou une liste Python mais qui n'est pas chargé entièrement en mémoire quand on l'utilise. Par exemple :
from BTrees.IOBTree import IOBTree
root = IOBTree() root[0] = "Python" root[1] = "Zope"
print root n'affichera pas ['Python', Zope] mais quelque chose du genre : <BTrees.IOBTree.IOBTree object at 0x87ecb24>
L'intérêt se situe lorsque l'on possède des milliers d'occurrences dans la base de données, qui en plus sont souvent imbriquées les unes dans les autres :
print root[1] # ne chargera pas en mémoire tout l'objet root mais juste l'occurrence numéro 1
Il existe plusieurs BTrees : OOBTree, IOBTree, OIBTree, IIBTree et IFBTree. La première lettre correspond à la clef et la seconde à la valeur, O pour Object, I pour Integer et F pour Float. Ainsi, IOBTree correspond à un BTree qu'on identifie avec un entier et qui peut contenir des objets.
Liens internes
[modifier | modifier le code]- « Release 6.0 », (consulté le )