Jadual Kandungan
Masukkan Rekod
Contoh
Output
Rumah pembangunan bahagian belakang tutorial php CakePHP Bekerja dengan Pangkalan Data

CakePHP Bekerja dengan Pangkalan Data

Sep 10, 2024 pm 05:25 PM
php cakephp PHP framework

Bekerja dengan pangkalan data dalam CakePHP adalah sangat mudah. Kami akan memahami operasi CRUD (Buat, Baca, Kemas Kini, Padam) dalam bab ini.

Selanjutnya, kami juga perlu mengkonfigurasi pangkalan data kami dalam fail config/app_local.php.

'Datasources' => [
   'default' => [
      'host' => 'localhost',
      'username' => 'my_app',
      'password' => 'secret',
      'database' => 'my_app',
      'url' => env('DATABASE_URL', null),
   ],
   /*
      * The test connection is used during the test suite.
   */
   'test' => [
      'host' => 'localhost',
      //'port' => 'non_standard_port_number',
      'username' => 'my_app',
      'password' => 'secret',
      'database' => 'test_myapp',
      //'schema' => 'myapp',
   ],
],

Sambungan lalai mempunyai butiran berikut −

'host' => 'localhost',
   'username' => 'my_app',
   'password' => 'secret',
   'database' => 'my_app',

Anda boleh menukar butiran, iaitu hos, nama pengguna, kata laluan dan pangkalan data mengikut pilihan anda.

Setelah selesai, pastikan ia dikemas kini dalam config/app_local.php dalam objek Datasources.

Sekarang, kami akan meneruskan butiran di atas, pergi ke pangkalan data phpmyadmin atau mysql anda dan buat pengguna my_app seperti yang ditunjukkan di bawah −

My App

Berikan keistimewaan yang diperlukan dan simpannya. Kini, kami mempunyai butiran pangkalan data mengikut konfigurasi yang dinyatakan dalam app_local.php. Apabila anda menyemak halaman utama CakePHP, inilah yang anda patut dapatkan −

App Local

Sekarang, kami akan mencipta jadual pengguna berikut dalam pangkalan data.

CREATE TABLE `users` ( 
   `id` int(11) NOT NULL AUTO_INCREMENT,
   `username` varchar(50) NOT NULL, 
   `password` varchar(255) NOT NULL, PRIMARY KEY (`id`) 
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=latin1

Masukkan Rekod

Untuk memasukkan rekod dalam pangkalan data, kita perlu mendapatkan jadual menggunakan kelas TableRegistry dahulu. Kami boleh mengambil contoh daripada pendaftaran menggunakan kaedah get(). Kaedah get() akan mengambil nama jadual pangkalan data sebagai hujah.

Acara baharu ini digunakan untuk mencipta entiti baharu. Tetapkan nilai yang diperlukan dengan contoh entiti baharu. Kini kita perlu memanggil kaedah save() dengan contoh kelas TableRegistry yang akan memasukkan rekod baharu dalam pangkalan data.

Contoh

Buat perubahan dalam fail config/routes.php seperti yang ditunjukkan dalam program berikut.

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/add', ['controller' => 'Users', 'action' => 'add']);
   $builder->fallbacks();
});

Buat fail UsersController.php di src/Controller/UsersController.php. Salin kod berikut dalam fail pengawal.

src/controller/UsersController.php

<?php namespace App\Controller;
use App\Controller\AppController;
use Cake\ORM\TableRegistry;
use Cake\Datasource\ConnectionManager;
use Cake\Auth\DefaultPasswordHasher;
class UsersController extends AppController{
   public function add(){
      if($this->request->is('post')){
         $username = $this->request->getData('username');
         $hashPswdObj = new DefaultPasswordHasher;
         $password = $hashPswdObj->hash($this->request->getData('password'));
         $users_table = TableRegistry::get('users');
         $users = $users_table->newEntity($this->request->getData());
         $users->username = $username;
         $users->password = $password;
         $this->set('users', $users);
         if($users_table->save($users))
         echo "User is added.";
      }
   }
}
?>

Buat direktori Pengguna di src/Template dan di bawah direktori itu cipta fail View yang dipanggil add.php. Salin kod berikut dalam fail itu.

src/Template/Users/add.php

<?php echo $this->Form->create(NULL,array('url'=>'/users/add'));
   echo $this->Form->control('username');
   echo $this->Form->control('password');
   echo $this->Form->button('Submit');
   echo $this->Form->end();
?>

Laksanakan contoh di atas dengan melawati URL berikut. http://localhost/cakephp4/users/add

Output

Setelah pelaksanaan, anda akan menerima output berikut.

CakePHP Bekerja dengan Pangkalan Data

Data akan disimpan dalam jadual pengguna seperti yang ditunjukkan di bawah −

Show All

Atas ialah kandungan terperinci CakePHP Bekerja dengan Pangkalan Data. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Stock Market GPT

Stock Market GPT

Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

MANTIANXING COMICS Versi Penuh Masuk_mantianxing Komik Pengiklanan Edisi Khas Pautan MANTIANXING COMICS Versi Penuh Masuk_mantianxing Komik Pengiklanan Edisi Khas Pautan Sep 28, 2025 am 10:30 AM

Versi penuh komik Mantixing adalah https://www.mantianxingmh.com. Platform ini merangkumi pelbagai tema seperti semangat, cinta, ketegangan, fiksyen sains, dan lain -lain, dengan sumber yang kaya dan kemas kini yang tepat pada masanya dan menyokong pengambilan semula diklasifikasikan; Ia menyediakan kualiti gambar definisi tinggi, mod beralih halaman, latar belakang tersuai dan pelarasan kecerahan, dan mempunyai mod perlindungan mata untuk mengoptimumkan pengalaman membaca; Pengguna boleh membuat rak buku, menyimpan rekod bacaan, muat turun di luar talian, dan mencapai kemajuan penyegerakan silang peranti.

Bagaimana cara menggunakan pengaturcaraan berorientasikan objek (OOP) dalam PHP? Bagaimana cara menggunakan pengaturcaraan berorientasikan objek (OOP) dalam PHP? Sep 28, 2025 am 03:26 AM

Oopinphporganizescodeintoreusableclassesandobjects.1.classdefinepropertymethods, instantiatedvia $ this.2.constructors (__ construct) InitializeObjectProperties.3.AccessModifiers (awam, swasta, dilindungi) Controlvisibility.4.Iherance)

Bagaimana cara memadam fail menggunakan php? Bagaimana cara memadam fail menggunakan php? Sep 27, 2025 am 06:08 AM

Gunakan fungsi Unlink () untuk memadam fail dalam PHP. Anda perlu memastikan bahawa laluan fail betul dan pelayan mempunyai kebenaran menulis. Sebelum penghapusan, anda harus mengesahkan bahawa fail itu wujud dan menghalang jalan daripada dimanipulasi secara berniat jahat.

Bagaimana untuk mendapatkan ID yang dimasukkan terakhir dalam php mysql? Bagaimana untuk mendapatkan ID yang dimasukkan terakhir dalam php mysql? Sep 28, 2025 am 05:57 AM

Gunakan mysqli_insert_id () (gaya prosedur), $ mysqli-> insert_id (gaya objek), atau $ pdo-> lastInsertId () (pdo) untuk mendapatkan ID dimasukkan terakhir dan perlu dipanggil dengan segera dalam sambungan yang sama untuk memastikan ketepatan.

Bagaimana cara menggunakan kelas dan kaedah akhir dalam PHP? Bagaimana cara menggunakan kelas dan kaedah akhir dalam PHP? Sep 28, 2025 am 05:55 AM

FinalclassesesandmethodsinphppreventinheritanceAndoverRidingToprotectcriticalcode.2.afinalclasscannotbeextended, memastikanSingitsbehaviorRemainSunchanged.3.afinalmethodcannotbeoverridden.

Cara menggema tag html dalam php Cara menggema tag html dalam php Sep 29, 2025 am 02:25 AM

Gunakan sebut harga tunggal atau melepaskan petikan berganda ke output HTML dalam PHP. Adalah disyorkan untuk membungkus rentetan dengan petikan tunggal untuk mengelakkan konflik petikan atribut. Kandungan dinamik boleh dihasilkan dalam kombinasi dengan splicing berubah atau sintaks Heredoc.

Bagaimana cara bekerja dengan mendapatkan pembolehubah permintaan dalam php? Bagaimana cara bekerja dengan mendapatkan pembolehubah permintaan dalam php? Sep 29, 2025 am 01:30 AM

Gunakan $ _getToAccessurlQueryStringVariablesInphp, suchasName = Johnandage = 30FromHttps: //example.com/search.php? Name = John & Age = 30;

Bagaimana untuk membuat kelas singleton di PHP? Bagaimana untuk membuat kelas singleton di PHP? Sep 27, 2025 am 06:18 AM

AsingletonclassinphpensuresonlyoneinstanceExistusingAprivateconstructor, mencegahCloningandunserialization, danProvidingaglobalaccesspointviaastaticmethodthatreturnsthesingleinstancestestoredinaprivatestaticaticyproperty.

See all articles