要更新資料庫中的記錄,我們首先需要使用 TableRegistry 類別取得表。我們可以使用 get() 方法從登錄中取得實例。 get() 方法將以資料庫表的名稱作為參數。現在,這個新實例用於取得我們想要更新的特定記錄。
使用這個新實例呼叫get()方法,並傳遞主鍵來尋找記錄,該記錄將保存在另一個實例中。使用此實例來設定要更新的新值,然後最後使用 TableRegistry 類別的實例呼叫 save() 方法來更新記錄。
在 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(); });
在 src/Controller/UsersController.php 建立一個 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的視圖。 將以下程式碼複製到該檔案中。
<a href="add">Add User</a>
ID | Username | Password | Edit | Delete | ".$row->id." | "; echo "".$row->username." | "; echo "".$row->password." | "; echo "Edit | "; echo "Delete | "; endforeach; ?>
在 Users 目錄下建立另一個 View 文件,名稱為 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 來執行上述範例,然後按一下編輯連結來編輯記錄。
http://localhost/cakephp4/users
存取上述網址後,會顯示users表中的記錄,如下所示 -
點擊編輯按鈕,它將顯示以下畫面 -
現在,我們將把名稱 CakePHP 更新一筆記錄 更新為 CakePHP 更新一筆記錄123 並提交詳細資訊。顯示的下一個畫面如下 -
以上是CakePHP 更新一筆記錄的詳細內容。更多資訊請關注PHP中文網其他相關文章!