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 ?

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 ?

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.

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

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

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Stock Market GPT
Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

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.

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.

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

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.

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

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.

AsingletonclassinphpensuresonlyoneinstanceExistusingAprivateconstructor, mencegahCloningandunserialization, danProvidingaglobalaccesspointviaastaticmethodthatreturnsthesingleinstancestestoredinaprivatestaticaticyproperty.

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