Rumah >pembangunan bahagian belakang >tutorial php >CakePHP mengandungi
CakePHP ialah rangka kerja sumber terbuka yang menyediakan tingkah laku dinamik pengaturcaraan. Selain itu, CakePHP menyediakan tingkah laku yang boleh dibendung, yang membantu menapis operasi dan membolehkan kami mengehadkan model. Dalam erti kata lain, kita boleh mengatakan bahawa mengikut keperluan kita, kita boleh mengurangkan pangkalan data kepada haus dan lusuh dua mod. Tambahan pula, selepas pelaksanaan CakePHP mengandungi, prestasi keseluruhan aplikasi akan dipertingkatkan. Tambahan pula, dengan menggunakan bekas CakePHP, kami melaksanakan penyelarasan dan pengikatan semasa pelaksanaan perisian, yang boleh membantu meningkatkan prestasi aplikasi.
Mulakan Kursus Pembangunan Perisian Percuma Anda
Pembangunan web, bahasa pengaturcaraan, ujian perisian & lain-lain
Tingkah Laku Tertahan. Tingkah laku teladan ini membenarkan anda menyalurkan dan mengehadkan tugasan menjejak model. Menggunakan Containable akan membantu anda menghapuskan perbatuan yang tidak perlu pada set data anda, mempercepatkan dan pelaksanaan umum aplikasi anda. Di samping itu, kelas akan membantu anda mencari dan menyalurkan maklumat anda untuk pelanggan anda dengan sempurna dan boleh diramalkan.
Containable membenarkan anda melicinkan dan menambah baik prosedur pada ikatan model anda. Ia berfungsi dengan mengubah suai hubungan model anda secara ringkas atau selama-lamanya. Ia melakukan ini dengan menggunakan kawalan yang disediakan untuk menghasilkan perkembangan panggilan bindModel dan unbindModel. Walau bagaimanapun, memandangkan Containable mengubah sambungan sedia ada, ia tidak membenarkan anda mengehadkan hasil mengikut gabungan jauh. Sebaliknya anda harus merujuk kepada Menyertai jadual.
Mari lihat bagaimana kita boleh menggunakan kaedah kandungan dalam CakePHP.
Siasatan penting dalam CakePHP 3.0 tidak sama dengan pertanyaan yang digunakan dalam CakePHP 2.0. Dalam 3.0, ORM (Perancangan Objek-sosial) yang digunakan untuk tugas berkaitan pentadbiran pangkalan maklumat telah berubah. Sebagai contoh, jika 'Emp' ialah model dan kami perlu membawa sebahagian daripada medan menggunakan pengilang pertanyaan, soalan akan kelihatan seperti di bawah:
$results=$emp->find() where(['id >'=>1]) toArray();
Penjelasan
Menggunakan pertanyaan di atas, kami akan menemui semua rekod yang idnya lebih besar daripada atau sama dengan 1. Kami menggambarkan hasil akhir pelaksanaan di atas menggunakan tangkapan skrin berikut.
Sekarang mari kita lihat contoh lain seperti berikut.
Bagaimana kalau kita ambil model ini? Terdapat dua jadual, sebagai contoh, 'Dept' dan 'Emp,' dengan banyak sambungan. Sekiranya kami ingin membawa data Jabatan yang berkaitan dengan Emp, maka, pada ketika itu, kami mempunyai kemungkinan untuk teknik 'mengandungi' untuk CakePHP. Dalam borang 3.0, kami mempunyai perintah penuh ke atas model yang berkaitan. Inilah pertanyaannya:
$results=$emp->find() contain(['Emp', Dept]) where(['id >'=>1]) toArray();
Penjelasan
Dalam contoh di atas, kami cuba melaksanakan kaedah mengandungi seperti yang ditunjukkan; di sini, kami menyertai dua yang berbeza dan mendapatkan hasil ke dalam satu jadual. Pelaksanaan di atas kami gambarkan dengan menggunakan tangkapan skrin berikut seperti berikut.
Jadi dengan cara ini, kita boleh melaksanakan kaedah mengandungi, serta kita juga boleh menambah lebih banyak kaedah mengikut keperluan kita seperti menaik, menurun, atau kadang-kadang kita perlu menapis rekod yang dikaitkan dengan jadual lain pada masa itu masa kita pun boleh guna kaedah contain.
Sekarang mari kita lihat bagaimana kita boleh menggunakan pernyataan cari dalam CakePHP seperti berikut.
Seperti yang dinyatakan sebelum ini, salah satu tugas lapisan Model ialah mendapatkan maklumat daripada kapasiti yang berbeza. Kelas Model CakePHP mengiringi beberapa kapasiti yang akan membantu anda mencari maklumat ini, menyusunnya, menomborkannya dan menyalurkannya. Kerja yang paling terkenal yang akan anda gunakan dalam model ialah model:find()
Sintaks
find (string $specified type = 'specified type', array $params = array())
Penjelasan
Menggunakan sintaks di atas, kita boleh melaksanakan pernyataan find; Cari ialah tenaga kerja pelbagai fungsi bagi semua kapasiti pemulihan maklumat model. $type boleh menjadi 'semua', 'pertama', 'kira', 'senarai', 'jiran' atau 'digantung', atau mana-mana pencari tersuai yang boleh anda cirikan. Ingat bahawa $type adalah kes kecil. Menggunakan aksara besar (contohnya, semua) tidak akan memberikan hasil yang diharapkan.
$params digunakan untuk melepasi semua sempadan kepada pelbagai jenis carian () dan mempunyai kekunci yang boleh difikirkan yang disertakan, sudah tentu, yang semuanya mengikut budi bicara:
Sekarang mari kita lihat kaedah pencarian yang berbeza seperti berikut.
Find(first)
Kita boleh menggunakan kaedah ini jika kita perlu mencetak hasil pertama atau menyebut hasil tunggal itu pada masa itu.
Sintaks
find('first', $All parameter)
Penjelasan
Dalam sintaks di atas, kami menggunakan kaedah cari dahulu; juga, kita perlu melepasi semua parameter.
Contoh
$result = $this -> Emp-> find('first');
Explanation
After executing the above statement, it returns the single record from the Emp table; the implementation of the above statement is illustrated by using the following screenshot.
find(count)
It is used to return the integer value as per our requirement.
Syntax
find('count', $All parameter)
Explanation
In the above syntax, we use the find method with the count method, and also here, we need to pass all parameters.
Example
$result = $this -> Emp-> find('count');
Explanation
We illustrated the final result of the above statement using the following screenshot.
find('all')
It is used to return a variety of different possible outcomes. Indeed, it is the component utilized by all find ( ) variations and paginates.
Syntax
find ('all', $All parameter) find('list')
It is used to return an ordered cluster, helpful for any spot where you would need a rundown, for example, for populating input select boxes.
Syntax
find ('list', $All parameter) find('threaded')
It is used to return a settled cluster and is fitting to utilize the parent_id field of your model information to fabricate settled outcomes.
Syntax
find ('threaded', $All parameter)
So in this way, we can implement the find statement as per our requirement; we can also write the above statement inside the function, depending on the requirement.
We hope from this article you learn more about CakePHP contain. From the above article, we have taken in the essential idea of the CakePHP contain, and we also see the representation and example of the CakePHP contain. Furthermore, we learned how and when we use the CakePHP contained in this article.
Atas ialah kandungan terperinci CakePHP mengandungi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!