データの永続性-ZODB
ZODB(Zope object Database)はPythonオブジェクトを格納するためのデータベースです。これはACIDに準拠しています-NOSQLデータベースにはない機能です。ZODBもオープンソースであり、多くのNoSQLデータベースと同様に、水平方向にスケーラブルでスキーマフリーです。ただし、配布されておらず、簡単なレプリケーションは提供されません。Pythonオブジェクトの永続化メカニズムを提供します。これはZopeアプリケーションサーバーの一部ですが、独立して使用することもできます。
ZODBは、ZopeCorporationのJimFultonによって作成されました。それは単純な永続オブジェクトシステムとして始まりました。現在のバージョンは5.5.0で、完全にPythonで記述されています。Pythonの組み込みオブジェクト永続性(pickle)の拡張バージョンを使用します。
ZODBの主な機能のいくつかは次のとおりです。
- transactions
- history/undo
- 透過的にプラグ可能なストレージ
- 組み込みのキャッシュ
- マルチバージョン同時実行制御(MVCC)
- ネットワーク全体のスケーラビリティ
ZODBは hierarchicalデータベース。データベースの作成時に初期化されるルートオブジェクトがあります。ルートオブジェクトはPython辞書のように使用され、他のオブジェクトを含めることができます(辞書のようにすることもできます)。オブジェクトをデータベースに保存するには、そのオブジェクトをコンテナ内の新しいキーに割り当てるだけで十分です。
ZODBは、データが階層的であり、書き込みよりも読み取りが多い可能性が高いアプリケーションに役立ちます。ZODBはpickleオブジェクトの拡張です。そのため、Pythonスクリプトでのみ処理できます。
最新バージョンのZODBをインストールするには、pipユーティリティを使用します-
pip install zodb
以下の依存関係もインストールされます-
- BTrees==4.6.1
- cffi==1.13.2
- persistent==4.5.1
- pycparser==2.19
- six==1.13.0
- transaction==2.4.0
ZODBは以下のストレージオプションを提供します-
ファイルストレージ
これがデフォルトです。基本的にトランザクションログである1つの大きなData.fsファイルに保存されているすべてのもの。
DirectoryStorage
これにより、オブジェクトリビジョンごとに1つのファイルが保存されます。この場合、クリーンでないシャットダウン時にData.fs.indexを再構築する必要はありません。
RelStorage
これにより、ピクルスがリレーショナルデータベースに保存されます。PostgreSQL、MySQL、およびOracleがサポートされています。
ZODBデータベースを作成するには、ストレージ、データベース、そして最後に接続が必要です。
最初のステップは、ストレージオブジェクトを用意することです。
import ZODB, ZODB.FileStorage
storage = ZODB.FileStorage.FileStorage('mydata.fs')
DBクラスは、このストレージオブジェクトを使用してデータベースオブジェクトを取得します。
db = ZODB.DB(storage)
インメモリデータベースを作成するには、DBコンストラクタにNoneを渡します。
Db=ZODB.DB(None)
最後に、データベースとの接続を確立します。
conn=db.open()
次に、接続オブジェクトは、「root()」メソッドを使用してデータベースの「ルート」にアクセスできるようにします。'root'オブジェクトは、すべての永続オブジェクトを保持する辞書です。
root = conn.root()
たとえば、次のように学生のリストをルートオブジェクトに追加します-
root['students'] = ['Mary', 'Maya', 'Meet']
この変更は、トランザクションをコミットするまでデータベースに永続的に保存されません。
import transaction
transaction.commit()
ユーザー定義クラスのオブジェクトを格納するには、クラスをpersistent.Persistent親クラスから継承する必要があります。
サブクラス化の利点
永続クラスのサブクラス化には、次のような利点があります。
データベースは、属性を設定することによって行われたオブジェクトの変更を自動的に追跡します。
データは独自のデータベースレコードに保存されます。
Persistentをサブクラス化しないデータを保存できますが、それを参照する永続オブジェクトのデータベースレコードに保存されます。非永続オブジェクトは、それらを含む永続オブジェクトによって所有され、複数の永続オブジェクトが同じ非永続サブオブジェクトを参照する場合、それらは独自のコピーを取得します。
永続クラスをサブクラス化する学生クラスを以下のように定義してみましょう。
import persistent
class student(persistent.Persistent):
def __init__(self, name):
self.name = name
def __repr__(self):
return str(self.name)
このクラスのオブジェクトを追加するには、最初に上記のように接続を設定しましょう。
import ZODB, ZODB.FileStorage
storage = ZODB.FileStorage.FileStorage('studentdata.fs')
db = ZODB.DB(storage)
conn=db.open()
root = conn.root()
オブジェクトをルートに追加することを宣言してから、トランザクションをコミットします
s1=student("Akash")
root['s1']=s1
import transaction
transaction.commit()
conn.close()
ルートオブジェクトは組み込みの辞書に似ているため、ルートに追加されたすべてのオブジェクトのリストは、items()メソッドを使用してビューオブジェクトとして取得できます。
print (root.items())
ItemsView({'s1': Akash})
ルートから特定のオブジェクトの属性をフェッチするには、
print (root['s1'].name)
Akash
オブジェクトは簡単に更新できます。ZODB APIは純粋なPythonパッケージであるため、外部SQLタイプの言語を使用する必要はありません。
root['s1'].name='Abhishek'
import transaction
transaction.commit()
データベースは即座に更新されます。トランザクションクラスは、SQLのrollback()トランザクション制御と同様のabort()関数も定義することに注意してください。