फाल्कन - ऑब्जेक्ट दस्तावेज़ मैपर
की अवधारणाओं के साथ शुरू करने से पहले Object Relational Mapper (ORM) और ऑब्जेक्ट डॉक्यूमेंट मैपर (ODM), SQL और NoSQL डेटाबेस के बीच अंतर को समझना महत्वपूर्ण है।
निम्न तालिका SQL और NoSQL के बीच के अंतर को उजागर करती है -
एसक्यूएल | NoSQL |
---|---|
उन्हें रिलेशनल डेटाबेस (RDBMS) भी कहा जाता है | उन्हें गैर-संबंधपरक या वितरित डेटाबेस कहा जाता है |
डेटाबेस की संरचना तालिकाओं और विचारों के रूप में गठित की जाती है | इसमें दस्तावेज़ आधारित और ग्राफ़ डेटाबेस शामिल हैं |
इसमें एक पूर्वनिर्धारित स्कीमा शामिल है | इसमें डायनेमिक स्कीमा है |
यह डेटा को परिभाषित करने और हेरफेर करने के लिए बहुत शक्तिशाली है | यह दस्तावेजों के संग्रह के रूप में डेटा को बनाए रखने में शक्तिशाली है |
फाल्कन में SQL और NoSQL डेटाबेस के साथ मैप करने की क्षमता है। यह SQL डेटाबेस के लिए ऑब्जेक्ट दस्तावेज़ मैपर (ODM) की मदद से और SQL डेटाबेस के लिए ऑब्जेक्ट रिलेशनल मैपर (ORM) के साथ प्राप्त किया गया है।
फाल्कन में, ORM अवधारणा में दिए गए तालिका-नाम से जुड़ा एक मॉडल बनाना शामिल है जैसा कि हमने पिछले अध्यायों में देखा है। यह सभी संदर्भात्मक अखंडता बाधाओं का अनुसरण करता है।
ऑब्जेक्ट दस्तावेज़ मैपर (ODM)
यह NoSQL डेटाबेस से जुड़ी वस्तु है। जैसा कि नाम से पता चलता है कि यह दस्तावेज़ से संबंधित मॉड्यूल को मैप करता है। फाल्कन इसका उपयोग MongoDB जैसे डेटाबेस के साथ मैप करने के लिए करता है।
उदाहरण
Step 1 - MongoDB नाम का एक डेटाबेस बनाएं “test”। हम इस डेटाबेस का उपयोग मानचित्र के साथ करेंगे और उचित प्रतिक्रिया प्राप्त करेंगे।
Step 2- डेटाबेस में सम्मिलित रिकॉर्ड की जाँच करें। इससे जुड़ी कमांड है -
db.collection.find()
यह देखा गया है कि हर दस्तावेज को ObjectId के साथ मैप किया जाता है जो कि ODM की एक विशेषता है। का मूल्यObjectId अद्वितीय है और बाद में उस विशेष आईडी के संबंध में संग्रहीत सभी डेटा प्राप्त करने के लिए उपयोग किया जाता है।
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;
}
}
आउटपुट डेटा प्रदर्शित करेगा जो ऑब्जेक्टआईड से मेल खाता है। यदि ऑब्जेक्ट को दस्तावेजों में रिकॉर्ड के अनुसार मिलान नहीं किया गया है, तो उपयुक्त आउटपुट प्रदर्शित नहीं किया जाएगा क्योंकि रिकॉर्ड की संख्या प्राप्त की जाती है।