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 |
|
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 |
|
Returns |
CI_DB_query_builder उदाहरण (विधि की रूपरेखा) |
Return Type |
CI_DB_query_builder |
where() फ़ंक्शन तय करेगा कि कौन सा रिकॉर्ड अपडेट करना है।
Syntax |
जहां ( $ कुंजी [, $ मूल्य = NULL [, $ बच = NULL ]]) |
Parameters |
|
Returns |
DB_query_builder उदाहरण |
Return Type |
वस्तु |
अंततः update() फ़ंक्शन डेटाबेस में डेटा को अपडेट करेगा।
Syntax |
अद्यतन ([ $ तालिका = '' [, $ सेट = NULL [, $ जहां = NULL [, $ सीमा = NULL ]]]] |
Parameters |
|
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 |
|
Returns |
CI_DB_query_builder उदाहरण (विधि का पीछा करना) या विफलता पर FALSE |
Return Type |
मिश्रित |
में एक रिकॉर्ड को हटाने के लिए निम्न कोड का उपयोग करें studतालिका। पहला तर्क रिकॉर्ड को हटाने के लिए तालिका के नाम को इंगित करता है और दूसरा तर्क यह तय करता है कि किस रिकॉर्ड को हटाना है।
$this->db->delete("stud", "roll_no = 1");
एक रिकॉर्ड का चयन करना
डेटाबेस में एक रिकॉर्ड का चयन करने के लिए, get फ़ंक्शन का उपयोग किया जाता है, जैसा कि निम्नलिखित तालिका में दिखाया गया है -
Syntax |
प्राप्त करें ([ $ तालिका = '' ], $ सीमा = NULL [, $ ऑफसेट = NULL ]]] |
Parameters |
|
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