Phalcon-オブジェクトドキュメントマッパー
の概念を始める前に Object Relational Mapper (ORM)とオブジェクトドキュメントマッパー(ODM)では、SQLデータベースとNoSQLデータベースの違いを理解することが重要です。
次の表は、SQLとNoSQLの違いを示しています。
SQL | NoSQL |
---|---|
これらは、リレーショナルデータベース(RDBMS)とも呼ばれます。 | それらは非リレーショナルまたは分散データベースと呼ばれます |
データベースの構造は、テーブルとビューで構成されています | ドキュメントベースのデータベースとグラフデータベースで構成されています |
事前定義されたスキーマが含まれています | 動的スキーマがあります |
データの定義と操作に非常に強力です | ドキュメントのコレクションとしてデータを維持するのに強力です |
Phalconには、SQLおよびNoSQLデータベースとマッピングする機能があります。これは、NoSQLデータベース用のオブジェクトドキュメントマッパー(ODM)とSQLデータベース用のオブジェクトリレーショナルマッパー(ORM)の助けを借りて実現されます。
Phalconでは、ORMの概念は、前の章で見たように、指定されたテーブル名に関連付けられたモデルを作成することで構成されます。これは、すべての参照整合性制約に従います。
オブジェクトドキュメントマッパー(ODM)
これは、NoSQLデータベースに関連付けられたオブジェクトです。名前が示すように、ドキュメント関連モジュールをマップします。Phalconはこれを使用して、MongoDBなどのデータベースとマッピングします。
例
Step 1 −という名前のMongoDBのデータベースを作成します “test”。このデータベースを使用して、適切な応答をマッピングして取得します。
Step 2−データベースに挿入されたレコードを確認します。それに関連付けられているコマンドは-です
db.collection.find()
すべてのドキュメントがODMの機能であるObjectIdでマップされていることが確認されています。の値ObjectId は一意であり、後でその特定のIDに関して保存されているすべてのデータをフェッチするために使用されます。
Step 3−作成したデータベースのモデルを設定します。モデルは拡張するクラスですPhalcon\Mvc\Collection。 Test.php モデルには次のコードが含まれます。
<?php
use Phalcon\Mvc\Collection;
class Test extends Collection {
public function initialize() {
$this->setSource("test");
}
}
Step 4 −データベース接続を含むプロジェクトを構成する services.php。
// Simple database connection to localhost
$di->set(
"mongo",
function () {
$mongo = new MongoClient();
return $mongo->selectDB("test");
},
true
);
// Connecting to a domain socket, falling back to localhost connection
$di->set(
"mongo",
function () {
$mongo = new MongoClient(
"mongodb:///tmp/mongodb-27017.sock,localhost:27017"
);
return $mongo->selectDB("test");
},
true
);
Step 5 −に関する値を出力します ObjectId の助けを借りて TestController.php。
<?php
use Phalcon\Mvc\Controller;
class TestController extends Controller {
public function index() {
// Find record with _id = "5087358f2d42b8c3d15ec4e2"
$test = Test::findById("5819ab6cfce9c70ac6087821");
echo $test->data;
}
}
出力には、objectIdに一致するデータが表示されます。ドキュメント内のレコードごとにobjectIdが一致しない場合、レコードの数がフェッチされるため、適切な出力は表示されません。