फाल्कन - डेटाबेस माइग्रेशन

डेटाबेस माइग्रेशन निम्न कारणों से महत्वपूर्ण है -

  • डेटाबेस माइग्रेशन निर्दिष्ट भंडारण प्रकारों के बीच डेटा स्थानांतरित करने में मदद करता है।

  • डेटाबेस माइग्रेशन एक प्लेटफ़ॉर्म से दूसरे प्लेटफ़ॉर्म पर जाने वाले वेब-आधारित अनुप्रयोगों के संदर्भ को संदर्भित करता है।

  • यह प्रक्रिया आमतौर पर डेटा का ट्रैक रखने के लिए होती है जो पुराना हो रहा है।

फाल्कन निम्नलिखित तरीके से डेटाबेस माइग्रेशन प्रक्रिया करता है -

Step 1 - नाम से एक प्रोजेक्ट बनाएं “dbProject” में xampp/wamp निर्देशिका।

Step 2 - उचित डेटाबेस कनेक्टिविटी के साथ प्रोजेक्ट को कॉन्फ़िगर करें।

<?php 

/*  
   * Modified: preppend directory path of current file, 
      because of this file own different ENV under between Apache and command line.  
   * NOTE: please remove this comment.  
*/

defined('BASE_PATH') || define('BASE_PATH', getenv('BASE_PATH') ?: realpath(dirname(__FILE__) . '/../..')); 
defined('APP_PATH') || define('APP_PATH', BASE_PATH . '/app');  
return new \Phalcon\Config(['database' => [
   'adapter' => 'Mysql', 
   'host' => 'localhost', 
   'username' => 'root', 
   'password' => '', 
   'dbname' => 'demodb', 
   'charset' => 'utf8', ],

'application' => [ 'appDir' => APP_PATH . '/', 
   'controllersDir' => APP_PATH . 
   '/controllers/', 'modelsDir' => APP_PATH . 
   '/models/', 'migrationsDir' => APP_PATH . 
   '/migrations/', 'viewsDir' => APP_PATH . 
   '/views/','pluginsDir' => APP_PATH . 
   '/plugins/', 'libraryDir' => APP_PATH . 
   '/library/', 'cacheDir' => BASE_PATH . 
   '/cache/', 'baseUri' => '/dbProject/', 
] ]);

Step 3- डेटाबेस "demodb" के भीतर शामिल तालिकाओं के प्रवास के लिए कमांड निष्पादित करें। अभी के लिए, इसमें एक तालिका "उपयोगकर्ता" शामिल है।

Step 4 - माइग्रेट की गई फ़ाइलों को "एप्लिकेशन" फ़ोल्डर में माइग्रेशन निर्देशिका के अंदर संग्रहीत किया जाता है।

इस प्रकार, तालिकाओं को सफलतापूर्वक माइग्रेट किया जाता है।

माइग्रेटेड फ़ाइलों के एनाटॉमी को समझना

माइग्रेटेड फ़ाइल में एक विशिष्ट वर्ग होता है जो विस्तारित होता है Phalcon\Mvc\Model\Migrationकक्षा। फाल्कन में प्रवासन वर्ग में विधियाँ शामिल हैंup() तथा down()up() पद्धति का उपयोग माइग्रेशन करने के लिए किया जाता है, जबकि डाउन विधि ऑपरेशन को वापस रोल करती है।

Users.php

<?php  

use Phalcon\Db\Column; 
use Phalcon\Db\Index; 
use Phalcon\Db\Reference; 
use Phalcon\Mvc\Model\Migration;  

/**  
   * Class UserMigration_100  
*/ 

class UserMigration_100 extends Migration {     
   /**      
      * Define the table structure      
      *      
      * @return void 
   */      
   public function morph() { 
      $this->morphTable('user', [ 
         'columns' => [ 
            new Column( 'Id', [ 
               'type' => Column::TYPE_INTEGER, 
               'notNull' => true, 
               'autoIncrement' => true, 
               'size' => 11, 'first' => true ] ), 
            new Column( 'username', [ 
               'type' => Column::TYPE_VARCHAR, 
               'notNull' => true, 
               'size' => 40, 
               'after' => 'Id' ] ), 
            new Column( 'email', [ 
               'type' => Column::TYPE_VARCHAR, 
               'notNull' => true, 
               'size' => 40, 
               'after' => 'username' ] ), 
            new Column( 'password', [ 
               'type' => Column::TYPE_VARCHAR, 
               'notNull' => true, 
               'size' => 10, 
               'after' => 'email' ] ) 
         ],  
         'indexes' => [new Index('PRIMARY', ['Id'], 'PRIMARY') ], 
            'options' => [ 'TABLE_TYPE' => 'BASE TABLE', 
               'AUTO_INCREMENT' => '3', 'ENGINE' => 'InnoDB', 
               'TABLE_COLLATION' => 'latin1_swedish_ci' ], 
      ] ); 
   }  
   
   /**      
      * Run the migrations      
      *      * @return void      
   */     

   public function up() {  
   }  

   /**      
      * Reverse the migrations      
      *
      * @return void      
   */
   public function down() {  
   } 
}

कक्षा UserMigration_100 जैसा कि ऊपर दिए गए उदाहरण में दिखाया गया है चार वर्गों के साथ साहचर्य सरणी शामिल हैं जो हैं -

  • Columns - टेबल कॉलम का एक सेट शामिल है।

  • Indexes - टेबल इंडेक्स का एक सेट शामिल है।

  • References - सभी संदर्भात्मक अखंडता बाधाओं (विदेशी कुंजी) शामिल हैं।

  • Options - तालिका निर्माण विकल्पों के एक सेट के साथ सरणी।

जैसा कि ऊपर दिए गए उदाहरण में देखा गया है, डेटाबेस का संस्करण 1.0.0 सफलतापूर्वक माइग्रेट किया गया था। फाल्कन में डेटाबेस सामग्री कैसे रखी जाती है, इसके आधार पर कई माइग्रेशन प्रक्रियाओं को शामिल और चला सकते हैं।