ZODB

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.

Zope Object Database

Informations
Développé par Zope Corporation
Dernière version 5.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 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

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

  • Portail de l’informatique
  • Portail des bases de données
  1. « Release 5.6.0 », (consulté le )
Cet article est issu de Wikipedia. Le texte est sous licence Creative Commons - Attribution - Partage dans les Mêmes. Des conditions supplémentaires peuvent s'appliquer aux fichiers multimédias.