


Mengurus operasi pangkalan data dengan cekap adalah penting untuk pembangunan aplikasi PHP. CRUD (Buat, Baca, Kemas Kini, Padam) ialah salah satu operasi pangkalan data yang paling biasa. Mengguna pakai prinsip pengaturcaraan berorientasikan objek (OOP) boleh membantu menjadikan kod anda lebih mudah dan lebih mudah untuk digunakan semula dan dikembangkan. Menggunakan MySQL dengan PHP juga memastikan aplikasi anda boleh mengendalikan penyimpanan data dengan cekap.
Siaran blog ini akan membimbing anda melalui cara membina aplikasi PHP CRUD menggunakan OOP dan MySQL. Kami akan mengikuti amalan terbaik dan corak reka bentuk untuk menyusun kod supaya ia mesra pemula namun cukup berkuasa untuk digunakan pada projek yang lebih besar.
Selepas membaca panduan ini, anda akan mempunyai asas yang kukuh untuk bekerja dengan pangkalan data menggunakan prinsip OOP dalam PHP.
Jadual Kandungan
- Kepentingan OOP dalam PHP
- Tetapan Projek
- Buat pangkalan data
- Struktur folder
- Sambung ke pangkalan data
- Buat operasi CRUD
- Buat
- Baca
- Kemas kini
- Padam
- Ringkasan
1. Kepentingan OOP dalam PHP
Pengaturcaraan berorientasikan objek (OOP) ialah paradigma pengaturcaraan yang menggunakan "objek" untuk menyusun kod. Dalam PHP, OOP membolehkan anda membuat kelas yang mewakili entiti dunia sebenar, menjadikan kod anda lebih modular, lebih mudah untuk digunakan semula dan lebih mudah untuk diurus.
Menggunakan prinsip OOP apabila bekerja dengan pangkalan data bermakna:
- Pemisahan Kebimbangan: Logik pangkalan data dikapsulkan dalam kelas, berasingan daripada logik aplikasi yang lain.
- Kebolehgunaan semula: Anda boleh menggunakan semula kelas pangkalan data dalam berbilang bahagian aplikasi anda.
- Kebolehselenggaraan: Apabila aplikasi anda berkembang, kod anda lebih mudah untuk dikemas kini dan dilanjutkan.
2. Tetapan projek
Sebelum kita memulakan pengekodan, mari sediakan struktur folder yang mudah diselenggara. Projek anda hendaklah disusun seperti berikut:
<code>php-crud/ ├── config/ │ └── Database.php ├── controllers/ │ └── UserController.php ├── models/ │ └── User.php ├── views/ │ └── user_list.php ├── public/ │ └── index.php └── .gitignore</code>
- config/Database.php: Mengandungi logik sambungan pangkalan data.
- pengawal/UserController.php: Mengendalikan operasi CRUD dan berkomunikasi dengan model.
- model/User.php: Mengandungi logik untuk berinteraksi dengan jadual pengguna dalam MySQL.
- views/user_list.php: Paparkan data pengguna dalam bentuk jadual.
- public/index.php: Titik masuk permohonan.
3. Cipta pangkalan data
Mari mulakan dengan mencipta pangkalan data dan jadual pengguna dalam MySQL. Anda boleh melaksanakan pertanyaan SQL berikut untuk menyediakan pangkalan data:
CREATE DATABASE php_crud; USE php_crud; CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(100) NOT NULL, email VARCHAR(100) NOT NULL, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP );
Jadual ini akan menyimpan maklumat pengguna asas seperti nama, e-mel dan tarikh penciptaan.
4. Struktur folder
Kami telah menyediakan struktur folder asas. Berikut ialah pecahan perkara yang dilakukan oleh setiap folder:
- config/: Mengandungi konfigurasi pangkalan data dan logik sambungan.
- pengawal/: Kendalikan permintaan dan panggil kaedah yang sepadan dalam model.
- model/: Mewakili logik perniagaan dan interaksi pangkalan data.
- pandangan/: Paparkan data kepada pengguna.
- awam/: Folder awam mengandungi fail index.php, yang akan berfungsi sebagai titik masuk ke aplikasi.
5. Sambung ke pangkalan data
Mari mulakan dengan mencipta kelas sambungan pangkalan data dalam config/Database.php:
<code>php-crud/ ├── config/ │ └── Database.php ├── controllers/ │ └── UserController.php ├── models/ │ └── User.php ├── views/ │ └── user_list.php ├── public/ │ └── index.php └── .gitignore</code>
Kelas ini mencipta sambungan PDO ke MySQL dan boleh digunakan semula dalam projek anda.
6. Cipta operasi CRUD
Mari kita cipta model untuk mengendalikan data pengguna. Kelas ini akan berinteraksi dengan jadual pengguna dan melaksanakan operasi CRUD.
Buat model (User.php)
CREATE DATABASE php_crud; USE php_crud; CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(100) NOT NULL, email VARCHAR(100) NOT NULL, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP );
Buat Pengawal (UserController.php)
<?php namespace Config; use PDO; class Database { private $host = '127.0.0.1'; private $dbName = 'php_crud'; private $username = 'root'; private $password = ''; private $connection; public function connect() { try { $this->connection = new PDO( "mysql:host={$this->host};dbname={$this->dbName}", $this->username, $this->password ); $this->connection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); return $this->connection; } catch (PDOException $e) { die("Database connection failed: " . $e->getMessage()); } } }
Buat paparan (senarai_pengguna.php)
<?php namespace Models; use Config\Database; class User { private $conn; public function __construct() { $database = new Database(); $this->conn = $database->connect(); } public function create($name, $email) { $sql = "INSERT INTO users (name, email) VALUES (:name, :email)"; $stmt = $this->conn->prepare($sql); $stmt->bindParam(':name', $name); $stmt->bindParam(':email', $email); return $stmt->execute(); } public function read() { $sql = "SELECT * FROM users"; $stmt = $this->conn->prepare($sql); $stmt->execute(); return $stmt->fetchAll(\PDO::FETCH_ASSOC); } public function update($id, $name, $email) { $sql = "UPDATE users SET name = :name, email = :email WHERE id = :id"; $stmt = $this->conn->prepare($sql); $stmt->bindParam(':name', $name); $stmt->bindParam(':email', $email); $stmt->bindParam(':id', $id); return $stmt->execute(); } public function delete($id) { $sql = "DELETE FROM users WHERE id = :id"; $stmt = $this->conn->prepare($sql); $stmt->bindParam(':id', $id); return $stmt->execute(); } }
Buat titik masuk (index.php)
<?php namespace Controllers; use Models\User; class UserController { public function createUser($name, $email) { $user = new User(); return $user->create($name, $email); } public function getUsers() { $user = new User(); return $user->read(); } public function updateUser($id, $name, $email) { $user = new User(); return $user->update($id, $name, $email); } public function deleteUser($id) { $user = new User(); return $user->delete($id); } }
Ringkasan
Dengan mengikut prinsip OOP dan menggunakan amalan terbaik dalam PHP, kami membina aplikasi CRUD yang mudah dan berskala. Pendekatan ini membolehkan anda dengan mudah memanjangkan projek anda dengan fungsi baharu atau menambah baik interaksi pangkalan data.
Dalam panduan ini, kami meliputi:
- Mudah dan mudah untuk mengekalkan struktur folder.
- Kelas Pangkalan Data boleh guna semula untuk sambungan MySQL.
- Model pengguna yang merangkumi semua operasi CRUD.
- Pengawal Pengguna untuk mengendalikan logik perniagaan.
Struktur ini menjadikan aplikasi PHP anda lebih bersih, lebih modular dan lebih mudah untuk dikembangkan. Anda kini boleh menggunakan pendekatan ini untuk membina aplikasi yang lebih besar dan lebih kompleks menggunakan OOP dan MySQL.
Selamat pengekodan! ?
Atas ialah kandungan terperinci Membina Aplikasi PHP CRUD dengan OOP dan MySQL: Panduan Amalan Terbaik. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

MySQL adalah sistem pengurusan pangkalan data relasi sumber terbuka, terutamanya digunakan untuk menyimpan dan mengambil data dengan cepat dan boleh dipercayai. Prinsip kerjanya termasuk permintaan pelanggan, resolusi pertanyaan, pelaksanaan pertanyaan dan hasil pulangan. Contoh penggunaan termasuk membuat jadual, memasukkan dan menanyakan data, dan ciri -ciri canggih seperti Operasi Join. Kesalahan umum melibatkan sintaks SQL, jenis data, dan keizinan, dan cadangan pengoptimuman termasuk penggunaan indeks, pertanyaan yang dioptimumkan, dan pembahagian jadual.

MySQL adalah sistem pengurusan pangkalan data sumber terbuka yang sesuai untuk penyimpanan data, pengurusan, pertanyaan dan keselamatan. 1. Ia menyokong pelbagai sistem operasi dan digunakan secara meluas dalam aplikasi web dan bidang lain. 2. Melalui seni bina pelanggan-pelayan dan enjin penyimpanan yang berbeza, MySQL memproses data dengan cekap. 3. Penggunaan asas termasuk membuat pangkalan data dan jadual, memasukkan, menanyakan dan mengemas kini data. 4. Penggunaan lanjutan melibatkan pertanyaan kompleks dan prosedur yang disimpan. 5. Kesilapan umum boleh disahpepijat melalui pernyataan yang dijelaskan. 6. Pengoptimuman Prestasi termasuk penggunaan indeks rasional dan pernyataan pertanyaan yang dioptimumkan.

MySQL dipilih untuk prestasi, kebolehpercayaan, kemudahan penggunaan, dan sokongan komuniti. 1.MYSQL Menyediakan fungsi penyimpanan dan pengambilan data yang cekap, menyokong pelbagai jenis data dan operasi pertanyaan lanjutan. 2. Mengamalkan seni bina pelanggan-pelayan dan enjin penyimpanan berganda untuk menyokong urus niaga dan pengoptimuman pertanyaan. 3. Mudah digunakan, menyokong pelbagai sistem operasi dan bahasa pengaturcaraan. 4. Mempunyai sokongan komuniti yang kuat dan menyediakan sumber dan penyelesaian yang kaya.

Mekanisme kunci InnoDB termasuk kunci bersama, kunci eksklusif, kunci niat, kunci rekod, kunci jurang dan kunci utama seterusnya. 1. Kunci dikongsi membolehkan urus niaga membaca data tanpa menghalang urus niaga lain dari membaca. 2. Kunci eksklusif menghalang urus niaga lain daripada membaca dan mengubah suai data. 3. Niat Kunci mengoptimumkan kecekapan kunci. 4. Rekod Rekod Kunci Kunci Rekod. 5. Gap Lock Locks Index Rakaman Gap. 6. Kunci kunci seterusnya adalah gabungan kunci rekod dan kunci jurang untuk memastikan konsistensi data.

Sebab -sebab utama prestasi pertanyaan MySQL yang lemah termasuk tidak menggunakan indeks, pemilihan pelan pelaksanaan yang salah oleh pengoptimasi pertanyaan, reka bentuk jadual yang tidak munasabah, jumlah data yang berlebihan dan persaingan kunci. 1. Tiada indeks menyebabkan pertanyaan perlahan, dan menambah indeks dapat meningkatkan prestasi dengan ketara. 2. Gunakan perintah Jelaskan untuk menganalisis pelan pertanyaan dan cari ralat pengoptimuman. 3. Membina semula struktur meja dan mengoptimumkan keadaan gabungan dapat meningkatkan masalah reka bentuk jadual. 4. Apabila jumlah data adalah besar, pembahagian dan strategi bahagian meja diterima pakai. 5. Dalam persekitaran konkurensi yang tinggi, mengoptimumkan urus niaga dan strategi mengunci dapat mengurangkan persaingan kunci.

Dalam pengoptimuman pangkalan data, strategi pengindeksan hendaklah dipilih mengikut keperluan pertanyaan: 1. Apabila pertanyaan melibatkan pelbagai lajur dan urutan syarat ditetapkan, gunakan indeks komposit; 2. Apabila pertanyaan melibatkan pelbagai lajur tetapi urutan syarat tidak ditetapkan, gunakan pelbagai indeks lajur tunggal. Indeks komposit sesuai untuk mengoptimumkan pertanyaan berbilang lajur, manakala indeks lajur tunggal sesuai untuk pertanyaan tunggal lajur.

Untuk mengoptimumkan pertanyaan perlahan MySQL, SlowQuerylog dan Performance_Schema perlu digunakan: 1. Dayakan SlowQueryLog dan tetapkan ambang untuk merakam pertanyaan perlahan; 2. Gunakan Performance_Schema untuk menganalisis butiran pelaksanaan pertanyaan, cari kesesakan prestasi dan mengoptimumkan.

MySQL dan SQL adalah kemahiran penting untuk pemaju. 1.MYSQL adalah sistem pengurusan pangkalan data sumber terbuka, dan SQL adalah bahasa standard yang digunakan untuk mengurus dan mengendalikan pangkalan data. 2.MYSQL menyokong pelbagai enjin penyimpanan melalui penyimpanan data yang cekap dan fungsi pengambilan semula, dan SQL melengkapkan operasi data yang kompleks melalui pernyataan mudah. 3. Contoh penggunaan termasuk pertanyaan asas dan pertanyaan lanjutan, seperti penapisan dan penyortiran mengikut keadaan. 4. Kesilapan umum termasuk kesilapan sintaks dan isu -isu prestasi, yang boleh dioptimumkan dengan memeriksa penyataan SQL dan menggunakan perintah menjelaskan. 5. Teknik pengoptimuman prestasi termasuk menggunakan indeks, mengelakkan pengimbasan jadual penuh, mengoptimumkan operasi menyertai dan meningkatkan kebolehbacaan kod.


Alat AI Hot

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

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

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod