CakePHP - एक रिकॉर्ड अपडेट करें

डेटाबेस में रिकॉर्ड को अपडेट करने के लिए, हमें सबसे पहले एक टेबल का उपयोग कर पकड़ना होगा TableRegistryकक्षा। हम रजिस्ट्री का उपयोग करके उदाहरण प्राप्त कर सकते हैंget()तरीका। get()विधि डेटाबेस तालिका का नाम तर्क के रूप में लेगा। अब, इस नए उदाहरण का उपयोग विशेष रिकॉर्ड प्राप्त करने के लिए किया जाता है जिसे हम अपडेट करना चाहते हैं।

बुलाएं get()इस नए उदाहरण के साथ विधि, और एक रिकॉर्ड खोजने के लिए प्राथमिक कुंजी को पास करें, जिसे किसी अन्य उदाहरण में सहेजा जाएगा। इस उदाहरण का उपयोग करें, नए मान सेट करने के लिए जिन्हें आप अपडेट करना चाहते हैं और फिर, अंत में कॉल करेंsave() के साथ विधि TableRegistry रिकॉर्ड को अद्यतन करने के लिए कक्षा का उदाहरण।

उदाहरण

निम्न कोड में दिखाए गए अनुसार config / मार्गों.php फ़ाइल में परिवर्तन करें।

config / routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf');
   //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('/users/edit', ['controller' => 'Users', 'action' => 'edit']);
   $builder->fallbacks();
});

बनाओ UsersController.php पर फ़ाइल करें src/Controller/UsersController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src / नियंत्रक / UsersController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\ORM\TableRegistry;
   use Cake\Datasource\ConnectionManager;
   class UsersController extends AppController{
      public function index(){
         $users = TableRegistry::get('users');
         $query = $users->find();
         $this->set('results',$query);
      }
      public function edit($id){
         if($this->request->is('post')){
            $username = $this->request->getData('username');
            $password = $this->request->getData('password');
            $users_table = TableRegistry::get('users');
            $users = $users_table->get($id);
            $users->username = $username;
            $users->password = $password;
            if($users_table->save($users))
            echo "User is udpated";
            $this->setAction('index');
         } else {
            $users_table = TableRegistry::get('users')->find();
            $users = $users_table->where(['id'=>$id])->first();
            $this->set('username',$users->username);
            $this->set('password',$users->password);
            $this->set('id',$id);
         }
      }
   }
?>

एक निर्देशिका बनाएँ Users at src/Template, यदि पहले से निर्मित है, तो अनदेखा करें, और उस निर्देशिका के तहत एक दृश्य बनाएं जिसे कहा जाता है index.php. उस फ़ाइल में निम्न कोड कॉपी करें।

src / खाका / उपयोगकर्ताओं / index.php

<a href="add">Add User</a>
<table>
   <tr>
   <td>ID</td>
   <td>Username</td>
   <td>Password</td>
   <td>Edit</td>
   <td>Delete</td>
   </tr>
   <?php
      foreach ($results as $row):
      echo "<tr><td>".$row->id."</td>";
      echo "<td>".$row->username."</td>";
      echo "<td>".$row->password."</td>";
      echo "<td><a href='".$this->Url->build(["controller" => "Users","action" => "edit",$row->id])."'>Edit</a></td>";
      echo "<td><a href='".$this->Url->build(["controller" => "Users","action" => "delete",$row->id])."'>Delete</a></td></tr>";
      endforeach;
   ?>
</table>

दूसरा बनाओ View उपयोगकर्ता निर्देशिका के तहत फ़ाइल कहा जाता है edit.php और इसमें निम्न कोड को कॉपी करें।

src / खाका / उपयोगकर्ताओं / edit.php

<?php
   echo $this->Form->create(NULL,array('url'=>'/users/edit/'.$id));
   echo $this->Form->control('username',['value'=>$username]);
   echo $this->Form->control('password',['value'=>$password]);
   echo $this->Form->button('Submit');
   echo $this->Form->end();
?>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें और क्लिक करें Edit link रिकॉर्ड संपादित करने के लिए।

http: // localhost / cakephp4 / उपयोगकर्ताओं

उत्पादन

उपरोक्त URL पर जाने के बाद, यह नीचे दिखाए गए अनुसार उपयोगकर्ताओं की तालिका में रिकॉर्ड प्रदर्शित करेगा -

Edit बटन पर क्लिक करें और यह आपको निम्न स्क्रीन प्रदर्शित करेगा -

अब, हम विराट नाम को विराट १२३ में अपडेट करेंगे और विवरण प्रस्तुत करेंगे। प्रदर्शित अगली स्क्रीन इस प्रकार होगी -