キーバリュー型データベース(英: key–value database)、またはキーバリュー型ストア(英: key–value store)は、連想配列の格納、取得、および管理するために設計されたデータストレージパラダイムであり、今日では辞書(英: dictionary)またはハッシュテーブル(英: hash table)として一般的に知られているデータ構造である。

概要

辞書はオブジェクトまたはレコードの集合を含み、レコードの中にはデータを含むさまざまなフィールドを持っている。これらのレコードは、レコードを一意に識別するキーを使用して保存および取得され、データベース内のデータを見つけるために使用される。

キーバリュー型データベースは、よく知られている関係データベース(英: relational database、RDB)とは大きく異なる方法で働く。RDBは、データベース内のデータ構造を、明確に定義されたデータ型のフィールドを含む一連のテーブルとして事前定義する。このデータ型をデータベースプログラムに開示することで、多くの最適化を適用できる。これに対してキーバリューシステムでは、データを単一の非開示の集合体として扱い、レコードごとに異なるフィールドを持つことができる。これはかなりの柔軟性を提供し、オブジェクト指向プログラミングのような現代的な概念をより追求している。ほとんどのRDBのように、オプションの値はプレースホルダや入力パラメータで表現されないため、キーバリュー型データベースでは、同じデータを格納するために使用するメモリがはるかに少ないことが多く、特定の作業負荷で性能が大きく向上する可能性がある。

性能面、標準化の欠如、その他の問題から、キーバリューシステムは長年ニッチな用途に限定されていた。しかし、2010年以降、クラウドコンピューティングへの急速な移行が進み、より広範なNoSQL移行の一部として再流行が起こった。ArangoDBのようなグラフデータベースも内部的にはキーバリュー型データベースであり、レコード間の関係(ポインタ)の概念を一級データ型として追加している。

種類と例

キーバリュー型データベースは、結果整合性から直列化可能性まで、一貫性モデルを使用することができる。キーの順序付けをサポートするものもある。

データをメモリ (RAM) に保持するものもあれば、ソリッドステートドライブや回転ディスクを使用するものもある。

すべての実体(entity、レコード)はキーとバリュー(値)の対からなる集合である。1つのキーは複数の要素を持ち、順序付きリストとして指定される。主分類キー(メジャーキー、major key)はレコードを識別するもので、キーの先頭の構成要素からなる。後続の構成要素は小分類キー(マイナーキー、minor keys)と呼ばれる。この構成は、ファイルシステムのディレクトリパス指定に似ている(例:/Major/minor1/minor2/)。 キー・バリュー対の「バリュー」の部分は、単に任意の長さをもつ未解釈のバイト文字列である。

Unix系システムではdbmが提供されており、もともとはケン・トンプソンによって1979年に書かれたライブラリであった。これは、Microsoft Windowsにも移植され、Perl for Win32などのプログラミング言語を通じて提供された。dbmは、任意のデータの連想配列を一つのキー(プライマリキー)で管理する。最近の実装には、sdbm、GNU dbm、Berkeley DBがある。dbmはNoSQLの概念に先行しており、現代の言説ではほとんど言及されないが、多くのソフトウェアで利用されている。

キーバリュー型データベースの最近の例としては、ArangoDBなど他のデータベース管理システムのストレージエンジンとして利用されているRocksDBがある。

脚注

参照項目

  • ビッグデータ
  • データ解析
  • 分散データストア
  • ドキュメント指向データベース
  • マルチモデルデータベース - 単一の統合されたバックエンドに対して、複数のデータモデルをサポートするように設計されたデータベース管理システム
  • タプル空間 - 並列/分散コンピューティングのための連想記憶パラダイムの実装

ビッグデータとIoTに特化した東芝デジタルの「GridDB」 Japan

【初心者向け】データベースとRDB

キー・バリュー形式のデータの処理・蓄積 共通教科情報科「情報Ⅰ」に向けた研修資料 あんこエデュケーション

キーバリュー形式で Python / Node.js / Java から InterSystems IRIS にアクセスできる Native

データベースの種類にはどんなものがあるのか?|図解を使って3分でわかりやすく解説します【データベース初心者向け】 YouTube