FuelPHP - मॉडल और डेटाबेस

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

एक मॉडल बनाना

फ्यूलपीईपी में, मॉडल केवल सादे PHP वर्ग है जो अंतर्निहित मॉडल वर्ग का विस्तार करता है। डिफ़ॉल्ट रूप से, मॉडल नियंत्रकों के समान Model_ के साथ उपसर्ग कर सकते हैं और उन्हें रखा जाना चाहिएfuel/app/classes/model/फ़ोल्डर। जैसे ही हम आगे बढ़ते हैं, हम एक बुनियादी कर्मचारी मॉडल बनाते हैं और इसे विस्तारित करते हैं।

ईंधन / ऐप्स / वर्गों / मॉडल / employee.php

<?php 
   namespace Model; 

   class Model_Employee extends \Model { 
      public static function fetchAll() { 
         // Code to fetch employee from database 
      } 
   }

एक मॉडल तक पहुंचें

एक बार एक मॉडल को परिभाषित करने के बाद, इसे किसी भी नियंत्रक में स्वतंत्र रूप से उपयोग किया जा सकता है, इसे निम्नानुसार नियंत्रक में शामिल किया जा सकता है।

use \Model\Employee; 

class Controller_Employee extends Controller { 
   public function action_index() { 
      $employees = Employee::fetchAll(); 
   } 
}

डेटाबेस अवलोकन

FuelPHP डेटाबेस से डेटा प्राप्त करने के लिए अपनी खुद की डेटाबेस एब्स्ट्रक्शन लेयर प्रदान करता है। यह दोनों बुनियादी और साथ ही उन्नत ORM आधारित उपकरण प्रदान करता है। मूल टूलकिट में DB, DBUtil और Query_Builer आधारित कक्षाएं शामिल हैं। उन्नत टूलकिट ओआरएम है। ऑरम टूलकिट बेस टूलकिट से लिया गया है और एक अलग पैकेज के रूप में बंडल किया गया है।

डेटाबेस कॉन्फ़िगरेशन

FuelPHP डेटाबेस सेटिंग्स को मुख्य कॉन्फ़िगरेशन फ़ाइल से अलग करता है और फ़ाइल है fuel/app/config/db.php। यह प्रत्येक वातावरण के लिए एक अलग सेटिंग का समर्थन करता है। वर्तमान में, FuelPHP MySQL, MySQLi और PDO ड्राइवरों का समर्थन करता है। नमूना सेटिंग निम्नानुसार है -

<?php  
   return array ( 
      'development' => array ( 
         'type'           => 'mysqli', 
         'connection'     => array ( 
            'hostname'    => 'localhost', 
            'port'        => '3306', 
            'database'    => 'tutorialspoint_fueldb', 
            'username'    => 'root', 
            'password'    => 'password', 
            'persistent'  => false, 
            'compress'    => false, 
         ), 
         
         'identifier'     => '`', 
         'table_prefix'   => '', 
         'charset'        => 'utf8', 
         'enable_cache'   => true, 
         'profiling'      => false, 
         'readonly'       => false, 
      ), 
   )

DB- आधारित टूलकिट

DB classआवेदन से डेटाबेस का उपयोग करने के लिए सबसे आसान विकल्प है। यह डेटाबेस क्वेरी बनाने के लिए विकल्प प्रदान करता है, इसे लक्ष्य डेटाबेस के विरुद्ध निष्पादित करता है, और अंत में परिणाम प्राप्त करता है। डीबी निम्नलिखित वर्गों के साथ वर्ग संपर्क रखता है और एक व्यापक डेटाबेस एपीआई प्रदान करता है।

  • Database_Connection - डेटाबेस के साथ बातचीत करने के लिए सिंगलटन और मुख्य वर्ग

  • Database_Query - एसक्यूएल क्वेरी को लाने के लिए आधार, ठोस वर्ग और परिणाम प्राप्त करें

  • Database_Query_Builder - SQL क्वेरी बनाने के लिए आधार, सार वर्ग

  • Database_Query_Builder_Join - SQL जॉइन करने के लिए क्लास

  • Database_Query_Builder_Where - एसक्यूएल क्वेरी शर्तों का निर्माण करने के लिए सार वर्ग

  • Database_Query_Builder_Select - एसक्यूएल चयन क्वेरी बनाने के लिए ठोस वर्ग

  • Database_Query_Builder_Insert एसक्यूएल डालने क्वेरी बनाने के लिए सार वर्ग

  • Database_Query_Builder_Update - एसक्यूएल अद्यतन क्वेरी बनाने के लिए सार वर्ग

  • Database_Query_Builder_Delete - एसक्यूएल हटाने क्वेरी बनाने के लिए सार वर्ग

निम्न आरेख वर्गों और वर्गों द्वारा प्रदान की गई विधियों के बीच संबंध को दर्शाता है।

डीबी एपीआई

आइए इस खंड में DB कक्षा में उपलब्ध सबसे महत्वपूर्ण विधियों को जानें।

उदाहरण

  • Purpose- नया डेटाबेस_संयोजन उदाहरण बनाता है और लौटाता है ।

  • Parameter -

    • $db - विन्यास फाइल में परिभाषित डेटाबेस कनेक्शन नाम, वैकल्पिक।

  • Returns- Database_Connection ऑब्जेक्ट लौटाता है

उदाहरण के लिए,

$db = DB::instance(); 
$db = DB::instance('test');

सवाल

  • Purpose - उपलब्ध एसक्यूएल स्टेटमेंट तैयार करें और डेटाबेस_डिस्क वस्तु लौटाएं, जिसका उपयोग डेटाबेस से डेटा डालने, अपडेट करने, हटाने या लाने के लिए किया जा सकता है।

  • Parameter -

    • $query - एसक्यूएल बयान, प्लेसहोल्डर हो सकता है;

    • $type - SQL प्रकार, वैकल्पिक (DB :: SELECT, DB :: INSERT, DB :: UPDATE और DB :: DELETE)

  • Returns- Database_Query ऑब्जेक्ट लौटाता है

उदाहरण के लिए,

$query = DB::query('SELECT * FROM 'employees'');

last_query

  • Purpose - अंतिम निष्पादित क्वेरी प्राप्त करने के लिए

  • Parameter - कोई नहीं

  • Returns - अंतिम निष्पादित क्वेरी लौटाता है

उदाहरण के लिए,

$employees = DB::Select('Select * from 'employee''); 
$sql = DB::last_query();

चुनते हैं

  • Purpose - क्वेरी के चुनिंदा हिस्से को जनरेट करें

  • Parameter -

    • $columns - डेटाबेस कॉलम नामों की सूची

  • Returns - Database_Query_Builder_Select ऑब्जेक्ट लौटाता है

उदाहरण के लिए,

$query = DB::select();              // Select *
$query = DB::select('id', 'name'); // Select id, name

select_array (DB)

यह चयन करने के समान है सिवाय इसके कि हम सरणी के रूप में कॉलम भेज सकें।

$query = DB::select_array(array('id', 'name')); // Select id, name

डालने

  • Purpose - क्वेरी के सम्मिलित भाग को उत्पन्न करें

  • Parameter -

    • $table_name - डेटाबेस तालिका का नाम;

    • $columns - टेबल कॉलम की सरणी

  • Returns - Database_Query_Builder_Insert ऑब्जेक्ट लौटाता है

उदाहरण के लिए,

$query = DB::insert('employee');  // Insert into employee 
$query = DB::insert('employee', array('id', 'name')); // Insert into employee (id, name)

अपडेट करें

  • Purpose - क्वेरी का अद्यतन भाग उत्पन्न करें

  • Parameter -

    • $table_name - डेटाबेस तालिका का नाम

  • Returns - Database_Query_Builder_Update ऑब्जेक्ट लौटाता है

उदाहरण के लिए,

$query = DB::update('employee'); // update `employee`

हटाना

  • Purpose - क्वेरी के डिलीट पार्ट को जनरेट करें

  • Parameter -

    • $table_name - डेटाबेस तालिका का नाम

  • Returns - Database_Query_Builder_Delete ऑब्जेक्ट देता है

उदाहरण के लिए

$query = DB::delete('employee');  // delete from 'employee'

क्वेरी API

Database_Queryडेटाबेस कनेक्शन सेट करने, क्वेरी निष्पादित करने और परिणाम को सहयोगी सरणी या ऑब्जेक्ट के रूप में लाने का विकल्प प्रदान करता है। चलिए देखते हैं Database_Query वर्ग द्वारा दिए गए तरीके।

set_connection

  • Purpose - क्वेरी को निष्पादित करने के लिए डेटाबेस (डेटाबेस कनेक्शन विवरण) सेट करना

  • Parameter - $ db - डेटाबेस कनेक्शन नाम

  • Returns- Database_Query ऑब्जेक्ट लौटाता है

उदाहरण के लिए,

$query = DB::query('DELETE * FROM employee', DB::DELETE); 
$query->set_connection('2nd-db');

परम

  • Purpose - क्वेरी ऑब्जेक्ट में परिभाषित पैरामीटर का मान सेट करने के लिए

  • Parameter -

    • $param - पैरामीटर नाम;

    • $value - पैरामीटर का मान

  • Returns- Database_Query ऑब्जेक्ट लौटाता है

उदाहरण के लिए,

// set some variables
$table = 'employee';
$id = 1;
$name = 'Jon';

// don't use
$query = DB::query('SELECT * FROM '.$table.'. WHERE id = '.$id.' AND name = "'.$name.'"');

// but use
$query = DB::query('SELECT * FROM :tablename WHERE id = :id AND name = :name');
$query->param('tablename', 'employee');
$query->param('id', $id);
$query->param('name', $name);

इसी तरह के तरीके

parameters एक समान वस्तु है, इसके अलावा यह एक साथ कई मूल्य देने का विकल्प प्रदान करता है।

$query->parameters (array( 
   'tablename' => $table, 
   'id' => $id, 
   'name' => $name 
});

बाँध

  • Purpose - क्वेरी ऑब्जेक्ट में परिभाषित पैरामीटर के लिए एक चर सेट करने के लिए

  • Parameter -

    • $param - पैरामीटर नाम

    • $var - पैरामीटर को बांधने के लिए चर

  • Returns- Database_Query ऑब्जेक्ट लौटाता है

उदाहरण के लिए,

// bind a query parameter 
$table = 'employee'; 
$query = DB::query('DELETE * FROM :tablename', DB::DELETE); 
$query->bind('tablename', $table);  

// update the variable 
$table = 'employee_salary'; 

// DELETE * FROM `employee_salary`; 
$sql = $query->compile();

संकलन

  • Purpose - SQL क्वेरी में परिभाषित क्वेरी ऑब्जेक्ट को संकलित करने के लिए

  • Parameter -

    • $db - कनेक्शन स्ट्रिंग, वैकल्पिक

  • Returns -

उदाहरण के लिए,

// assign a value to a query parameter 
$table = 'employee'; 
$query = DB::query('DELETE * FROM :tablename', DB::DELETE); 
$query->param('tablename', $table);

// compile the query, returns: DELETE * FROM employee 
$sql = $query->compile();

निष्पादित

  • Purpose - क्वेरी ऑब्जेक्ट में परिभाषित क्वेरी को निष्पादित करने और परिणाम वापस करने के लिए

  • Parameter -

    • $db - डेटाबेस कनेक्शन का नाम

  • Returns - परिणाम लौटाता है

उदाहरण के लिए,

// assign a value to a query parameter 
$table = 'employee'; 
$query = DB::query('DELETE * FROM :tablename', DB::DELETE); 
$query->param('tablename', $table);  

// execute the query 
$query->execute();

as_assoc

  • Purpose - वस्तुओं के बजाय साहचर्य सरणी के रूप में वापसी प्रकार सेट करने के लिए

  • Parameter - कोई नहीं

  • Returns - वर्तमान वस्तु को लौटाता है

उदाहरण के लिए,

$query = DB::query('SELECT * FROM employee', DB::SELECT); 
$result = $query->as_assoc()->execute(); 
foreach ($result as $row) { 
   echo $row['id']; 
}

as_object

  • Purpose - साहचर्य सरणी के बजाय वापसी प्रकार को ऑब्जेक्ट के रूप में सेट करने के लिए

  • Parameter - कोई नहीं

  • Returns - वर्तमान वस्तु को लौटाता है

उदाहरण के लिए,

$query = DB::query('SELECT * FROM employee', DB::SELECT); 
$result = $query->as_object()->execute(); 
foreach ($result as $row) { 
   echo $row->id; 
}  

// have ORM model objects return instead 
$result = $query->as_object('Model_Employee')->execute();

क्वेरी बिल्डर एपीआई

क्वेरी बिल्डर (Query_Builder) आधारित कक्षाएं गतिशील रूप से SQL क्वेरी बनाने के लिए विकल्प प्रदान करती हैं। इसमें चार वर्ग हैं, प्रत्येक को (Query_Builder_Select) , इंसर्ट (Query_Builder_Insert) , अपडेट (Query_Builder_Update) डालें और हटाएं (Query_Builder_Delete) क्वेरीज़। ये कक्षाएं Query_Builder_Where वर्ग (स्थितियों को उत्पन्न करने का विकल्प) से ली गई हैं, जो स्वयं ही सभी वर्गों के आधार Query_Builder से ली गई हैं।

आइए हम Query_Builder वर्ग द्वारा प्रदान की गई विधियों को देखें।

चुनते हैं

  • Purpose - चुनिंदा प्रश्नों के कॉलम जनरेट करने के लिए।

  • Parameter -

    • $columns - कॉलम की सूची, वैकल्पिक

  • Returns - वर्तमान उदाहरण लौटाता है

उदाहरण के लिए,

$query = DB::select('name')  // select `name` 
$query = DB::select(array('first_name', 'name')) // select `first_name` as `name`

से

  • Purpose - चुनिंदा प्रश्नों का तालिका विवरण तैयार करने के लिए

  • Parameter -

    • $tables - तालिकाओं की सूची

  • Returns - वर्तमान उदाहरण लौटाता है

उदाहरण के लिए,

$query = DB::select('name')->from('employee') // select `name` from `employee`

कहाँ पे

  • Purpose - प्रश्नों का चयन करने, सम्मिलित करने और अद्यतन करने की शर्तों को उत्पन्न करने के लिए

  • Parameters -

    • $column - कॉलम का नाम या सरणी ($ कॉलम, $ उपनाम);

    • $op - लॉजिक ऑपरेटर, =; =!, IN, BETWEEN और LIKE, वैकल्पिक;

    • $value - स्तंभ मान

  • Returns - वर्तमान उदाहरण लौटाता है

उदाहरण के लिए,

$query = DB::select('name')->from('employee')  
$query = $query->where('name', '=', 'Jon'); 
// select `name` from `employee` where `name` = `Jon`;

इसी तरह के तरीके

इसी तरह की विधियां हैं जहां_ओपेन (), और_से_ओपेन (), या_से_ओपेन (), जहां_क्लास (), और_से_क्लोज (), या_से_क्लोज ()। वे कहाँ () विधियों के समान हैं सिवाय इसके कि वे अतिरिक्त कीवर्ड और कोष्ठक को शर्तों के आसपास जोड़ते हैं। निम्नलिखित एक नमूना कोड है।

$query = DB::select('*')->from('employee');  
$query->where('email', 'like', '%@gmail.com'); 
$query->or_where_open(); 
$query->where('name', 'Jon'); 
$query->and_where('surname', 'Peter');
$query->or_where_close();  
// SELECT * FROM `employee` WHERE `email` LIKE "%gmail.com" OR 
   (`name` = "Jon" AND `surname` = "Peter")

में शामिल होने के

  • Purpose - चुनिंदा प्रश्नों की तालिका जॉइन करने के लिए

  • Parameters -

    • $table - तालिका का नाम या सरणी ($ तालिका, $ अन्य);

    • $type - ज्वाइन टाइप (LEFT, RIGHT, INNER, आदि)

  • Returns - वर्तमान उदाहरण लौटाता है

उदाहरण

$query = DB::select('name')->from('employee')->join('employee_salary') 
// select `name` from `employee` JOIN `employee_salary`

पर

  • Purpose - चुनिंदा प्रश्नों में जुड़ने की स्थिति उत्पन्न करना

  • Parameters -

    • $c1 - सारणी में उपनाम के साथ तालिका का नाम या तालिका का नाम;

    • $op - तार्किक ऑपरेटर;

    • $c2 - सारणी में उपनाम के साथ तालिका का नाम या तालिका का नाम

  • Returns - वर्तमान उदाहरण लौटाता है

उदाहरण के लिए,

$query = DB::select('name')->from('employee')->join('employee_salary') 
$query = $query->on('employee.employee_id', '=', 'employee_salary.employee_id') 
// select `name` from `employee` JOIN `employee_salary` on 
// `employee.employee_id` = `employee_salary.employee_id`

इसी तरह के तरीके

संबंधित तरीके हैं और_ऑन () और or_on ()। वे पर () के समान हैं सिवाय इसके कि वे अतिरिक्त कीवर्ड और कोष्ठक जोड़ते हैं।

समूह द्वारा

  • Purpose - प्रश्नों द्वारा समूह उत्पन्न करने के लिए

  • Parameter - $columns - कॉलम नाम जिसके द्वारा परिणाम को समूहित किया जाता है

  • Returns - वर्तमान उदाहरण लौटाता है

उदाहरण के लिए,

$query = DB::select('name')->from('employee')  
$query = $query->group_by('name'); 
// select `name` from `employee` group by `name`

बीत रहा है

  • Purpose - एसक्यूएल प्रश्नों की शर्तों द्वारा समूह उत्पन्न करने के लिए

  • Parameter - $column - कॉलम का नाम या सरणी ($ कॉलम, $ उपनाम); $op - लॉजिक ऑपरेटर, =; =!, IN, BETWEEN और LIKE, वैकल्पिक; $value - स्तंभ मान

  • Returns - वर्तमान उदाहरण लौटाता है

उदाहरण

$query = DB::select('name')->from('employee')
$query = $query->group_by('name');
$query = $query->having('name', '!=', 'Jon');
// select `name` from `employee` group by `name` having `name` != `Jon`

इसी तरह के तरीके

इसी तरह के तरीके हैं_ओपेन (), और_हिंगिंग_ोपेन (), या_हिंगिंग_ओपेन (), होने_क्लोज (), और_होस्टिंग_क्लोज (), या_होस्टिंग_क्लोज ()। वे होने () विधियों के समान हैं सिवाय इसके कि वे अतिरिक्त कीवर्ड और कोष्ठक को शर्तों के आसपास जोड़ते हैं।

रीसेट

  • Purpose - क्वेरी को रीसेट करने के लिए

  • Parameter - कोई नहीं

  • Returns - वर्तमान उदाहरण लौटाता है

उदाहरण के लिए,

$query = DB::select('name')->from('employee')  
$query->reset() 
$query = DB::select('name')->from('employee_salary') 
// select `name` from `employee_salary`

DBUtil वर्ग

DBUtil वर्ग नियमित डेटाबेस संचालन का प्रबंधन और प्रदर्शन करने का विकल्प प्रदान करता है। कुछ महत्वपूर्ण तरीके इस प्रकार हैं -

  • set_connection - डिफ़ॉल्ट कनेक्शन सेट करता है
DBUtil::set_connection('new_database');
  • create_database - एक डेटाबेस बनाता है।
DBUtil::create_database('my_database');
  • drop_database - एक डेटाबेस को ड्रॉप करता है।
DBUtil::drop_database('my_database');
  • table_exists - यदि दी गई तालिका मौजूद है, तो जाँच करता है।
if(DBUtil::table_exists('my_table')) { 
   // Table exists 
} else { 
   // Table does NOT exist, create it! 
}
  • drop_table - एक टेबल गिरता है।
DBUtil::drop_table('my_table');
  • create_table - एक तालिका बनाता है।
\DBUtil::create_table ( 
   'users', 
   array ( 
      'id' => array('type' => 'int', 'auto_increment' => true), 
      'name' => array('type' => 'text'), 
   ), 
);

ऑरम टूलकिट

ईंधनपीएचपी लोकप्रिय के आधार पर ओआरएम अवधारणा का उपयोग करके उन्नत डेटाबेस परत प्रदान करता है Active record pattern। टूलकिट एप्लिकेशन में शामिल है लेकिन डिफ़ॉल्ट रूप से कॉन्फ़िगर नहीं किया गया है। इसे पैकेज के रूप में बंडल किया जाता है और पैकेज का नाम ओआरएम होता है। हम मुख्य कॉन्फ़िगरेशन फ़ाइल में निम्न कॉन्फ़िगरेशन जोड़ सकते हैं,fuel/app/config/config.php ओआरएम टूलकिट लोड करने के लिए।

'always_load' => array ( 
   'packages' => array (
      'orm', 
   ), 
),

मॉडल बनाना

ओआरएम आधार मॉडल वर्ग प्रदान करता है ऑरम \ मॉडल। हमें ओआरएम सुविधाओं का उपयोग करने के लिए अपने मॉडल को ऑरम मॉडल के साथ विस्तारित करने की आवश्यकता है। निम्नलिखित एक नमूना कोड है।

class Model_Employee extends Orm\Model {}

विन्यास

ओआरएम सुविधाओं का उपयोग करने के लिए मॉडल को कॉन्फ़िगर करने के लिए ओआरएम सेटिंग्स का एक सेट प्रदान करता है। वे इस प्रकार हैं -

connection- कनेक्शन नाम निर्दिष्ट करने के लिए मॉडल में एक स्थिर _connection गुण सेट करें ।

class Model_Employee extends Orm\Model { 
   protected static $_connection = "production"; 
}

table name- बैकएंड टेबल के टेबल का नाम निर्दिष्ट करने के लिए मॉडल में एक स्थिर _table_name गुण सेट करें ।

class Model_Employee extends Orm\Model { 
   protected static $_table_name = 'employee'; 
}

primary key- बैकएंड टेबल की प्राथमिक कुंजी निर्दिष्ट करने के लिए मॉडल में एक स्थैतिक _primary_key गुण सेट करें ।

class Model_Employee extends Orm\Model { 
   protected static $_primary_key = array('id'); 
}

Columns- बैकएंड टेबल के कॉलम को निर्दिष्ट करने के लिए मॉडल में एक स्थिर _प्रोटेटी गुण सेट करें। यह data_type, label, validation, form elememts, आदि का समर्थन करता है।

class Model_Employee extends Orm\Model { 
   protected static $_properties = array ( 
      'id',  
      'name' => array ( 
         'data_type' => 'varchar', 
         'label' => 'Employee Name', 
         'validation' => array ( 
            'required',  
            'min_length' => array(3),  
            'max_length' > array(80) 
         ), 
         
         'form' => array ( 
            'type' => 'text' 
         ), 
      ),  

      'age' => array ( 
         'data_type' => 'int', 
         'label' => 'Employee Age', 
         'validation' => array ( 
            'required',  
         ),  
         
         'form' => array ( 
            'type' => 'text' 
         ), 
      ),  
   ); 
}

Conditions- विकल्पों द्वारा शर्तों और व्यवस्था को निर्धारित करने के लिए एक स्थिर _conditions गुण सेट करें।

class Model_Employee extends Orm\Model { 
   protected static $_conditions = array ( 
      'order_by' => array('id' => 'desc'), 
      'where' => array ( 
         array('is_active', > true), 
      ), 
   ); 
}

Observers- ओआरएम विशिष्ट घटनाओं में व्यवहार जोड़ने के लिए पर्यवेक्षक आधारित घटना प्रणाली प्रदान करता है। किसी व्यवहार को जोड़ने के लिए, पहले मॉडल में _observers गुण सेट करें । फिर, व्यवहार को एक वर्ग के रूप में परिभाषित करें और घटनाओं के साथ इसे _observers संपत्ति में सेट करें । यदि कोई घटना निर्दिष्ट नहीं है, तो व्यवहार को सभी घटनाओं के लिए लागू किया जाएगा। हम कई व्यवहार भी निर्दिष्ट कर सकते हैं।

class Model_Employee { 
   protected static $_observers = array ( 
      'example',  // will call Observer_Example class for all events 
      'Orm\\Observer_CreatedOn' => array ( 
         'events' => array('before_insert'),  
         // will only call Orm\Observer_CreatedOn at before_insert event 
      ) 
   ); 
}

सृजन करना

एक बार जब हम मॉडल को कॉन्फ़िगर करते हैं, तो हम सीधे तरीकों का उपयोग करना शुरू कर सकते हैं। ओआरएम डेटाबेस में ऑब्जेक्ट को बचाने के लिए एक बचत विधि प्रदान करता है । हम कॉन्फ़िगर किए गए गुणों का उपयोग करके डेटा को निम्नानुसार सेट कर सकते हैं -

// option 1 
$new = new Model_Employee(); 
$new->name = 'Jon'; 
$new->save();  

// option 2, use forge instead of new 
$new = Model_Employee::forge();
$new->name = 'Jon'; 
$new->save();  

// option 3, use array for properties 
$props = array('name' => 'Jon'); 
$new = Model_Employee::forge($props); 
$new>save();

पढ़ें

ओआरएम एक विधि प्रदान करता है, डेटाबेस से डेटा प्राप्त करने और ऑब्जेक्ट में बांधने के लिए ढूंढें। खोज विधि इनपुट पैरामीटर के आधार पर काम करती है। आइए हम विभिन्न विकल्पों को देखें -

by primary key - प्राथमिक कुंजी निर्दिष्ट करना कॉन्फ़िगर की गई तालिका की प्राथमिक कुंजी से मेल करके रिकॉर्ड देता है।

$employee = Model_Employee::find(1);

first / last record- 'पहले' या 'अंतिम' को निर्दिष्ट करने से क्रमशः पहला रिकॉर्ड या अंतिम रिकॉर्ड प्राप्त होगा। हम विकल्प के रूप में भी आदेश पारित कर सकते हैं।

$entry = Model_Employee::find('first'); 
$entry = Model_Article::find('last', array('order_by' => 'id'));

All- 'सभी' को निर्दिष्ट करने से कॉन्फ़िगर की गई तालिका से सभी रिकॉर्ड प्राप्त होंगे। हम विकल्प के साथ-साथ शर्तों के अनुसार ऑर्डर निर्दिष्ट कर सकते हैं।

$entry = Model_Employee::find('all');  
$entry = Model_Article::find ('all', array ( 
   'where' => array ( 
      array ('name', 'Jon'), 
   ), 
   'order_by' => array ('id' => 'desc'), 
));

हम उन्नत खोज विकल्प के लिए मॉडल के साथ बुनियादी डेटाबेस टूलकिट के क्वेरी एपीआई का उपयोग निम्नानुसार कर सकते हैं।

$query = Model_Employee::query()->where('category_id', 1)->order_by('date', 'desc');
$number_of_employees = $query->count(); 
$latest_employee = $query->max('id'); 
$young_employee = $query->min('age'); 
$newest_employee = $query->get_one(); 
$employees = $query->limit(15)->get();

अपडेट करें

मॉडल बनाना अपडेट करने के समान है, नए मॉडल बनाने के बजाय केवल खोज विधि का उपयोग करके अपडेट किए जाने वाले मॉडल को लाने के लिए, संपत्ति को अपडेट करें और फिर निम्नानुसार सेव विधि को कॉल करें।

$entry = Model_Employee:find(4);
$entry->name = 'Peter'; 
$entry->save();

हटाएं

मॉडल को हटाने के लिए ओआरएम एक डिलीट विधि प्रदान करता है। बस ऑब्जेक्ट प्राप्त करें और हटाएं विधि को कॉल करें।

$entry = Model_Employee:find(4); 
$entry->delete();

काम करने का उदाहरण

आइए मॉडल और डेटाबेस को समझने के लिए इस अध्याय में एक कार्यशील उदाहरण बनाएं।

एक डेटाबेस बनाएँ

निम्नलिखित कमांड का उपयोग करके MySQL सर्वर में एक नया डेटाबेस बनाएँ।

create database tutorialspoint_fueldb

फिर, निम्नलिखित कमांड का उपयोग करके डेटाबेस के अंदर एक टेबल बनाएं।

create table employee(id int primary key, name varchar(20), age int not null);

डेटाबेस को कॉन्फ़िगर करें

डेटाबेस विन्यास फाइल, * फ्यूल / एप / कॉन्फिग / db.php का उपयोग करके डेटाबेस को कॉन्फ़िगर करते हैं। MySQL सर्वर को जोड़ने के लिए निम्नलिखित परिवर्तन जोड़ें।

<?php  
   return array ( 
      'development' => array ( 
         'type'           => 'mysqli', 
         'connection'     => array ( 
            'hostname'       => 'localhost', 
            'port'           => '3306', 
            'database'       => 'tutorialspoint_fueldb', 
            'username'       => 'root', 
            'password'       => 'pass', 
            'persistent'     => false, 
            'compress'       => false, 
         ), 
         
         'identifier'     => '`', 
         'table_prefix'   => '', 
         'charset'        => 'utf8', 
         'enable_cache'   => true, 
         'profiling'      => false, 
         'readonly'       => false, 
      ),  
      
      'production' => array ( 
         'type'           => 'mysqli', 
         'connection'     => array ( 
            'hostname'       => 'localhost', 
            'port'           => '3306', 
            'database'       => 'tutorialspoint_fueldb', 
            'username'       => 'root', 
            'password'       => 'pass', 
            'persistent'     => false, 
            'compress'       => false, 
         ), 
         
         'identifier'     => '`', 
         'table_prefix'   => '', 
         'charset'        => 'utf8', 
         'enable_cache'   => true, 
         'profiling'      => false, 
         'readonly'       => false, 
      ), 
   );

ORM पैकेज शामिल करें

मुख्य कॉन्फ़िगरेशन फ़ाइल को अपडेट करें, fuel/app/config/config.php निम्नलिखित कॉन्फ़िगरेशन को जोड़कर ORM पैकेज शामिल करें।

'always_load' => array ( 
   'packages' => array ( 
      'orm' 
   ), 
),

अब, ORM आपके एप्लिकेशन में सक्षम है

कर्मचारी मॉडल बनाएं

मॉडल फ़ोल्डर के तहत एक नया मॉडल, कर्मचारी बनाएं “fuel/app/classes/model”। इसे निम्नानुसार परिभाषित किया गया है।

Employee.php

<?php  
   class Model_Employee extends Orm\Model { 
      protected static $_connection = 'production'; 
      protected static $_table_name = 'employee'; 
      protected static $_primary_key = array('id'); 
      protected static $_properties = array ( 
         'id',  
         'name' => array ( 
            'data_type' => 'varchar', 
            'label' => 'Employee Name', 
            'form' => array (
               'type' => 'text' 
            ), 
         ),  
         
         'age' => array ( 
            'data_type' => 'int', 
            'label' => 'Employee Age', 
            'form' => array ( 
               'type' => 'text' 
            ), 
         ),  
      ); 
   }

क्रिया बनाएँ

नई कार्रवाई बनाएं, action_model कर्मचारी नियंत्रक स्थित में fuel/app/classes/controller/employee.php निम्नलिखित नुसार।

class Controller_Employee extends Controller { 
   public function action_model() { 
      
      // db based sql command to delete all employees 
      $query = db::query('delete from `employee`'); 
      $query->execute('production');  
      
      // orm based query to add new employees 
      $model = new model_employee(); 
      $model->name = "john"; 
      $model->age = 25; 
      $model->save();  
      $model = new model_employee(); 
      $model->name = "peter"; 
      $model->age = 20; 
      $model->save(); 
      
      // orm based query to fetch all employee data 
      $data = array(); 
      $data['emps'] = model_employee::find('all');  
      return response::forge(view::forge('employee/model', $data)); 
   } 
}

दृश्य बनाएँ

अब, एक व्यू फाइल बनाएं model.php स्थित है “fuel/app/views/employee”। फ़ाइल में निम्न परिवर्तन जोड़ें।

<ul> 
   <?php 
      foreach($emps as $emp) {  
   ?> 
   <li><?php echo $emp['name']; ?></li> 
   
   <?php 
   } 
   ?> 
</ul>

अब, URL का अनुरोध करें, http://localhost:8080/employee/model और यह निम्नलिखित परिणाम का उत्पादन करेगा।

परिणाम