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\CollectionTest.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が一致しない場合、レコードの数がフェッチされるため、適切な出力は表示されません。