CodeIgniter - डेटाबेस के साथ काम करना

किसी भी अन्य ढांचे की तरह, हमें डेटाबेस के साथ बहुत बार बातचीत करने की आवश्यकता है और कोडइग्निटर इस काम को हमारे लिए आसान बनाता है। यह डेटाबेस के साथ बातचीत करने के लिए कार्यात्मकताओं का समृद्ध सेट प्रदान करता है।

इस अनुभाग में, हम यह समझेंगे कि कैसे CRUD (Create, Read, Update, Delete) फ़ंक्शंस CodeIgniter के साथ काम करते हैं। हम इस्तेमाल करेंगेstud डेटा का चयन करने, अद्यतन करने, हटाने और सम्मिलित करने के लिए तालिका stud तालिका।

तालिका का नाम: स्टड
अनुक्रमांक पूर्णांक (11)
नाम varchar (30)

डेटाबेस से कनेक्ट करना

हम निम्नलिखित दो तरीकों से डेटाबेस से जुड़ सकते हैं -

  • Automatic Connecting- फ़ाइल कनेक्शन / config / autoload.php का उपयोग करके स्वचालित कनेक्शन किया जा सकता है। स्वचालित कनेक्शन प्रत्येक पृष्ठ के लिए डेटाबेस को लोड करेगा। हमें बस डेटाबेस लाइब्रेरी जोड़ने की आवश्यकता है जैसा कि नीचे दिखाया गया है -

$autoload['libraries'] = array(‘database’);
  • Manual Connecting- यदि आप केवल कुछ पृष्ठों के लिए डेटाबेस कनेक्टिविटी चाहते हैं, तो हम मैनुअल कनेक्टिंग के लिए जा सकते हैं। हम किसी भी वर्ग में निम्नलिखित लाइन को जोड़कर मैन्युअल रूप से डेटाबेस से जुड़ सकते हैं।

$this->load->database();

यहां, हम किसी भी तर्क को पारित नहीं कर रहे हैं क्योंकि सब कुछ डेटाबेस में सेट है फ़ाइल का अनुप्रयोग / config / database.php

एक रिकॉर्ड सम्मिलित करना

डेटाबेस में एक रिकॉर्ड डालने के लिए, सम्मिलित () फ़ंक्शन का उपयोग निम्न तालिका में दिखाया गया है -

Syntax

सम्मिलित करें ([ $ तालिका = '' [, $ सेट = NULL [, $ बच = NULL ]]]

Parameters

  • $table( स्ट्रिंग ) - तालिका का नाम

  • $set( एरे ) - फील्ड / वैल्यू पेयर का एक ऐररेटिव ऐरे

  • $escape( बूल ) - मूल्यों और पहचानकर्ताओं से बचना है या नहीं

Returns

सफलता पर सफलता, विफलता पर FALSE

Return Type

bool

निम्न उदाहरण दिखाता है कि रिकॉर्ड कैसे सम्मिलित किया जाए studतालिका। $ डेटा एक सरणी है जिसमें हमने डेटा सेट किया है और इस डेटा को तालिका में सम्मिलित करने के लिएstud, हम सिर्फ 2 एन डी तर्क में डालने के समारोह के लिए इस सरणी को पारित करने की जरूरत है ।

$data = array( 
   'roll_no' => ‘1’, 
   'name' => ‘Virat’ 
); 

$this->db->insert("stud", $data);

एक रिकॉर्ड अद्यतन करना

डेटाबेस में रिकॉर्ड अपडेट करने के लिए, update() समारोह के साथ प्रयोग किया जाता है set() तथा where()नीचे दी गई तालिकाओं में दिखाए गए कार्य। set() फ़ंक्शन अपडेट किए जाने वाले डेटा को सेट करेगा।

Syntax

सेट ( $ कुंजी [, $ मूल्य = '' [, $ बच = NULL ]])

Parameters

  • $key( मिश्रित ) - फ़ील्ड नाम, या फ़ील्ड / मान जोड़े की एक सरणी

  • $value( स्ट्रिंग ) - फ़ील्ड मान, यदि $ कुंजी एकल फ़ील्ड है

  • $escape( बूल ) - मूल्यों और पहचानकर्ताओं से बचना है या नहीं

Returns

CI_DB_query_builder उदाहरण (विधि की रूपरेखा)

Return Type

CI_DB_query_builder

where() फ़ंक्शन तय करेगा कि कौन सा रिकॉर्ड अपडेट करना है।

Syntax

जहां ( $ कुंजी [, $ मूल्य = NULL [, $ बच = NULL ]])

Parameters

  • $key( मिश्रित ) - तुलना करने के लिए क्षेत्र का नाम, या साहचर्य सरणी

  • $value( मिश्रित ) - यदि इस मूल्य की तुलना में एक एकल कुंजी

  • $escape( बूल ) - मूल्यों और पहचानकर्ताओं से बचना है या नहीं

Returns

DB_query_builder उदाहरण

Return Type

वस्तु

अंततः update() फ़ंक्शन डेटाबेस में डेटा को अपडेट करेगा।

Syntax

अद्यतन ([ $ तालिका = '' [, $ सेट = NULL [, $ जहां = NULL [, $ सीमा = NULL ]]]]

Parameters

  • $table( स्ट्रिंग ) - तालिका का नाम

  • $set( एरे ) - फील्ड / वैल्यू पेयर का एक ऐररेटिव ऐरे

  • $where( स्ट्रिंग ) - WHERE क्लॉज

  • $limit( int ) - सीमा खंड

Returns

सफलता पर सफलता, विफलता पर FALSE

Return Type

bool
$data = array( 
   'roll_no' => ‘1’, 
   'name' => ‘Virat’ 
); 

$this->db->set($data); 
$this->db->where("roll_no", ‘1’); 
$this->db->update("stud", $data);

रिकॉर्ड हटाना

डेटाबेस में एक रिकॉर्ड को हटाने के लिए, डिलीट () फ़ंक्शन का उपयोग निम्न तालिका में दिखाया गया है -

Syntax

हटाएं ([ $ तालिका = '' [, $ जहाँ = '' [, $ सीमा = NULL [, $ reset_data = TRUE ]]]]

Parameters

  • $table( मिश्रित ) - से हटाने के लिए तालिका; स्ट्रिंग या सरणी

  • $where( स्ट्रिंग ) - WHERE क्लॉज

  • $limit( int ) - सीमा खंड

  • $reset_data( बूल ) - क्वेरी "राइट" क्लॉज को रीसेट करने की कोशिश करें

Returns

CI_DB_query_builder उदाहरण (विधि का पीछा करना) या विफलता पर FALSE

Return Type

मिश्रित

में एक रिकॉर्ड को हटाने के लिए निम्न कोड का उपयोग करें studतालिका। पहला तर्क रिकॉर्ड को हटाने के लिए तालिका के नाम को इंगित करता है और दूसरा तर्क यह तय करता है कि किस रिकॉर्ड को हटाना है।

$this->db->delete("stud", "roll_no = 1");

एक रिकॉर्ड का चयन करना

डेटाबेस में एक रिकॉर्ड का चयन करने के लिए, get फ़ंक्शन का उपयोग किया जाता है, जैसा कि निम्नलिखित तालिका में दिखाया गया है -

Syntax

प्राप्त करें ([ $ तालिका = '' ], $ सीमा = NULL [, $ ऑफसेट = NULL ]]]

Parameters

  • $table( स्ट्रिंग ) - तालिका सारणी सरणी के लिए

  • $limit( int ) - सीमा खंड

  • $offset( int ) - OFFSET क्लॉज

Returns

CI_DB_result उदाहरण (विधि श्रृंखलन)

Return Type

CI_DB_result

डेटाबेस से सभी रिकॉर्ड प्राप्त करने के लिए निम्न कोड का उपयोग करें। पहला बयान "स्टड" तालिका से सभी रिकॉर्ड प्राप्त करता है और ऑब्जेक्ट को लौटाता है, जिसे $ क्वेरी ऑब्जेक्ट में संग्रहीत किया जाएगा। दूसरा बयान कहता हैresult() सरणी के रूप में सभी रिकॉर्ड प्राप्त करने के लिए $ क्वेरी ऑब्जेक्ट के साथ कार्य करें।

$query = $this->db->get("stud"); 
$data['records'] = $query->result();

एक कनेक्शन बंद करना

डेटाबेस कोड को मैन्युअल रूप से बंद किया जा सकता है, निम्नलिखित कोड निष्पादित करके -

$this->db->close();

उदाहरण

नामक एक नियंत्रक वर्ग बनाएँ Stud_controller.php और इसे बचाओ application/controller/Stud_controller.php

यहां एक पूर्ण उदाहरण है, जिसमें उपर्युक्त सभी ऑपरेशन किए जाते हैं। निम्नलिखित उदाहरण को निष्पादित करने से पहले, इस अध्याय की शुरुआत में निर्देशानुसार डेटाबेस और तालिका बनाएं और डेटाबेस में संग्रहीत फ़ाइल में आवश्यक परिवर्तन करें।application/config/database.php

<?php 
   class Stud_controller extends CI_Controller {
	
      function __construct() { 
         parent::__construct(); 
         $this->load->helper('url'); 
         $this->load->database(); 
      } 
  
      public function index() { 
         $query = $this->db->get("stud"); 
         $data['records'] = $query->result(); 
			
         $this->load->helper('url'); 
         $this->load->view('Stud_view',$data); 
      } 
  
      public function add_student_view() { 
         $this->load->helper('form'); 
         $this->load->view('Stud_add'); 
      } 
  
      public function add_student() { 
         $this->load->model('Stud_Model');
			
         $data = array( 
            'roll_no' => $this->input->post('roll_no'), 
            'name' => $this->input->post('name') 
         ); 
			
         $this->Stud_Model->insert($data); 
   
         $query = $this->db->get("stud"); 
         $data['records'] = $query->result(); 
         $this->load->view('Stud_view',$data); 
      } 
  
      public function update_student_view() { 
         $this->load->helper('form'); 
         $roll_no = $this->uri->segment('3'); 
         $query = $this->db->get_where("stud",array("roll_no"=>$roll_no));
         $data['records'] = $query->result(); 
         $data['old_roll_no'] = $roll_no; 
         $this->load->view('Stud_edit',$data); 
      } 
  
      public function update_student(){ 
         $this->load->model('Stud_Model');
			
         $data = array( 
            'roll_no' => $this->input->post('roll_no'), 
            'name' => $this->input->post('name') 
         ); 
			
         $old_roll_no = $this->input->post('old_roll_no'); 
         $this->Stud_Model->update($data,$old_roll_no); 
			
         $query = $this->db->get("stud"); 
         $data['records'] = $query->result(); 
         $this->load->view('Stud_view',$data); 
      } 
  
      public function delete_student() { 
         $this->load->model('Stud_Model'); 
         $roll_no = $this->uri->segment('3'); 
         $this->Stud_Model->delete($roll_no); 
   
         $query = $this->db->get("stud"); 
         $data['records'] = $query->result(); 
         $this->load->view('Stud_view',$data); 
      } 
   } 
?>

नामक एक मॉडल वर्ग बनाएँ Stud_Model.php और इसे में सहेजें application/models/Stud_Model.php

<?php 
   class Stud_Model extends CI_Model {
	
      function __construct() { 
         parent::__construct(); 
      } 
   
      public function insert($data) { 
         if ($this->db->insert("stud", $data)) { 
            return true; 
         } 
      } 
   
      public function delete($roll_no) { 
         if ($this->db->delete("stud", "roll_no = ".$roll_no)) { 
            return true; 
         } 
      } 
   
      public function update($data,$old_roll_no) { 
         $this->db->set($data); 
         $this->db->where("roll_no", $old_roll_no); 
         $this->db->update("stud", $data); 
      } 
   } 
?>

नामक एक दृश्य फ़ाइल बनाएँ Stud_add.php और इसे में सहेजें application/views/Stud_add.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>Students Example</title> 
   </head> 
   <body> 
         <?php 
            echo form_open('Stud_controller/add_student');
            echo form_label('Roll No.'); 
            echo form_input(array('id'=>'roll_no','name'=>'roll_no')); 
            echo "<br/>"; 
			
            echo form_label('Name'); 
            echo form_input(array('id'=>'name','name'=>'name')); 
            echo "<br/>"; 
			
            echo form_submit(array('id'=>'submit','value'=>'Add')); 
            echo form_close(); 
         ?> 
   </body>
</html>

नामक एक दृश्य फ़ाइल बनाएँ Stud_edit.php और इसे में सहेजें application/views/Stud_edit.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>Students Example</title> 
   </head> 
	
   <body> 
      <form method = "" action = "">
		
         <?php 
            echo form_open('Stud_controller/update_student'); 
            echo form_hidden('old_roll_no',$old_roll_no); 
            echo form_label('Roll No.'); 
            echo form_input(array('id'⇒'roll_no',
               'name'⇒'roll_no','value'⇒$records[0]→roll_no)); 
            echo "
            "; 

            echo form_label('Name'); 
            echo form_input(array('id'⇒'name','name'⇒'name',
               'value'⇒$records[0]→name)); 
            echo "
            "; 

            echo form_submit(array('id'⇒'sub mit','value'⇒'Edit')); 
            echo form_close();
         ?> 
			
      </form> 
   </body>
	
</html>

नामक एक दृश्य फ़ाइल बनाएँ Stud_view.php और इसे में सहेजें application/views/Stud_view.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>Students Example</title> 
   </head>
	
   <body> 
      <a href = "<?php echo base_url(); ?>
         index.php/stud/add_view">Add</a>
		
      <table border = "1"> 
         <?php 
            $i = 1; 
            echo "<tr>"; 
            echo "<td>Sr#</td>"; 
            echo "<td>Roll No.</td>"; 
            echo "<td>Name</td>"; 
            echo "<td>Edit</td>"; 
            echo "<td>Delete</td>"; 
            echo "<tr>"; 
				
            foreach($records as $r) { 
               echo "<tr>"; 
               echo "<td>".$i++."</td>"; 
               echo "<td>".$r->roll_no."</td>"; 
               echo "<td>".$r->name."</td>"; 
               echo "<td><a href = '".base_url()."index.php/stud/edit/"
                  .$r->roll_no."'>Edit</a></td>"; 
               echo "<td><a href = '".base_url()."index.php/stud/delete/"
                  .$r->roll_no."'>Delete</a></td>"; 
               echo "<tr>"; 
            } 
         ?>
      </table> 
		
   </body>
	
</html>

रूट फ़ाइल में निम्न परिवर्तन करें application/config/routes.php और फ़ाइल के अंत में निम्न पंक्ति जोड़ें।

$route['stud'] = "Stud_controller"; 
$route['stud/add'] = 'Stud_controller/add_student'; 
$route['stud/add_view'] = 'Stud_controller/add_student_view'; 
$route['stud/edit/(\d+)'] = 'Stud_controller/update_student_view/$1'; 
$route['stud/delete/(\d+)'] = 'Stud_controller/delete_student/$1';

अब, ब्राउज़र में निम्नलिखित URL पर जाकर इस उदाहरण को निष्पादित करते हैं। अपने URL के साथ yoursite.com बदलें।

http://yoursite.com/index.php/stud