


Créer une application PHP CRUD avec POO et MySQL?: un guide des meilleures pratiques
Jan 11, 2025 am 07:20 AMLa gestion efficace des opérations de base de données est cruciale pour le développement d'applications PHP. CRUD (Créer, Lire, Mettre à jour, Supprimer) est l'une des opérations de base de données les plus courantes. L'adoption des principes de programmation orientée objet (POO) peut contribuer à rendre votre code plus simple et plus facile à réutiliser et à étendre. L'utilisation de MySQL avec PHP garantit également que votre application peut gérer efficacement le stockage des données.
Cet article de blog vous expliquera comment créer une application PHP CRUD en utilisant OOP et MySQL. Nous suivrons les meilleures pratiques et les modèles de conception pour organiser le code de manière à ce qu'il soit convivial pour les débutants mais suffisamment puissant pour être utilisé sur des projets plus importants.
Après avoir lu ce guide, vous disposerez d'une base solide pour travailler avec des bases de données utilisant les principes de la POO en PHP.
Table des matières
- L'importance de la POO en PHP
- Paramètres du projet
- Créer une base de données
- Structure des dossiers
- Se connecter à la base de données
- Créer des opérations CRUD
- Créer
- Lire
- Mise à jour
- Supprimer
- Résumé
1. L'importance de la POO en PHP
La programmation orientée objet (POO) est un paradigme de programmation qui utilise des ? objets ? pour organiser le code. En PHP, la POO vous permet de créer des classes qui représentent des entités du monde réel, rendant votre code plus modulaire, plus facile à réutiliser et à gérer.
Appliquer les principes de la POO lorsque vous travaillez avec des bases de données signifie?:
- Séparation des préoccupations?: la logique de la base de données est encapsulée dans une classe, distincte du reste de la logique de l'application.
- Réutilisabilité?: Vous pouvez réutiliser les classes de base de données dans plusieurs parties de votre application.
- Maintenabilité?: à mesure que votre application se développe, votre code est plus facile à mettre à jour et à étendre.
2. Paramètres du projet
Avant de commencer à coder, mettons en place une structure de dossiers facile à gérer. Votre projet doit être organisé comme suit?:
<code>php-crud/ ├── config/ │ └── Database.php ├── controllers/ │ └── UserController.php ├── models/ │ └── User.php ├── views/ │ └── user_list.php ├── public/ │ └── index.php └── .gitignore</code>
- config/Database.php?: Contient la logique de connexion à la base de données.
- controllers/UserController.php?: gère les opérations CRUD et communique avec le modèle.
- models/User.php?: Contient la logique pour interagir avec la table des utilisateurs dans MySQL.
- views/user_list.php?: Afficher les données utilisateur sous forme de tableau.
- public/index.php : Le point d'entrée de l'application.
3. Créer une base de données
Commen?ons par créer la base de données et la table des utilisateurs dans MySQL. Vous pouvez exécuter la requête SQL suivante pour configurer la base de données?:
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 );
Ce tableau stockera les informations de base sur l'utilisateur telles que le nom, l'e-mail et la date de création.
4. Structure des dossiers
Nous avons mis en place la structure de base des dossiers. Voici un aper?u de ce que fait chaque dossier?:
- config/?: Contient la configuration de la base de données et la logique de connexion.
- controllers/?: Gère la requête et appelle la méthode correspondante dans le modèle.
- models/?: représente la logique métier et l'interaction avec la base de données.
- views/?: Afficher les données à l'utilisateur.
- public/ : Le dossier public contient le fichier index.php, qui servira de point d'entrée à l'application.
5. Connectez-vous à la base de données
Commen?ons par créer une classe de connexion à la base de données dans config/Database.php?:
<code>php-crud/ ├── config/ │ └── Database.php ├── controllers/ │ └── UserController.php ├── models/ │ └── User.php ├── views/ │ └── user_list.php ├── public/ │ └── index.php └── .gitignore</code>
Cette classe crée une connexion PDO à MySQL et est réutilisable dans votre projet.
6. Créer des opérations CRUD
Créons un modèle pour gérer les données utilisateur. Cette classe interagira avec la table des utilisateurs et effectuera des opérations CRUD.
Créer un modèle (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 );
Créer un contr?leur (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()); } } }
Créer une vue (user_list.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(); } }
Créer un point d'entrée (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); } }
Résumé
En suivant les principes de la POO et en appliquant les meilleures pratiques en PHP, nous avons construit une application CRUD simple et évolutive. Cette approche vous permet d'étendre facilement votre projet avec de nouvelles fonctionnalités ou d'améliorer l'interaction avec la base de données.
Dans ce guide, nous couvrons?:
- Structure de dossiers simple et facile à gérer.
- Classe de base de données réutilisable pour les connexions MySQL.
- Modèle utilisateur qui encapsule toutes les opérations CRUD.
- UserController pour gérer la logique métier.
Cette structure rend vos applications PHP plus propres, plus modulaires et plus faciles à étendre. Vous pouvez désormais utiliser cette approche pour créer des applications plus volumineuses et plus complexes à l'aide de la POO et de MySQL.
Bon codage?! ?
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

MySQLDump est un outil commun pour effectuer des sauvegardes logiques des bases de données MySQL. Il génère des fichiers SQL contenant des instructions de création et d'insertion pour reconstruire la base de données. 1. Il ne sauvegarde pas le fichier d'origine, mais convertit la structure de la base de données et le contenu en commandes SQL portables; 2. Il convient aux petites bases de données ou à la récupération sélective et ne convient pas à la récupération rapide des données de niveau TB; 3. 4. Utilisez la commande MySQL pour importer pendant la récupération et peut désactiver les vérifications des clés étrangères pour améliorer la vitesse; 5. Il est recommandé de tester régulièrement la sauvegarde, d'utiliser la compression et de régler automatiquement.

Pour afficher la taille de la base de données et de la table MySQL, vous pouvez interroger directement l'information_schema ou utiliser l'outil de ligne de commande. 1. Vérifiez la taille de la base de données entière: exécutez l'instruction SQL selectTable_schemaas'database ', sum (data_length index_length) / 1024 / 1024as'size (MB)' frominformation_schema.tablesgroupbyTable_schema; Vous pouvez obtenir la taille totale de toutes les bases de données ou ajouter où les conditions limitent la base de données spécifique; 2. Vérifiez la taille unique de la table: utilisez SELECTTA

Les problèmes de règles de jeu de caractères et de tri sont courants lors de la migration multiplateforme ou du développement multi-personnes, entra?nant un code brouillé ou une requête incohérente. Il existe trois solutions principales: d'abord, vérifiez et unifiez le jeu de caractères de la base de données, de la table et des champs vers UTF8MB4, affichez via ShowCreateDatabase / Table, et modifiez-le avec une instruction alter; Deuxièmement, spécifiez le jeu de caractères UTF8MB4 lorsque le client se connecte et le définissez dans les paramètres de connexion ou exécutez SetNames; Troisièmement, sélectionnez les règles de tri raisonnablement et recommandez d'utiliser UTF8MB4_UNICODE_CI pour assurer la précision de la comparaison et du tri, et spécifiez ou modifiez-la via ALTER lors de la construction de la bibliothèque et du tableau.

MySQL prend en charge le traitement des transactions et utilise le moteur de stockage InNODB pour garantir la cohérence et l'intégrité des données. 1. Les transactions sont un ensemble d'opérations SQL, soit tous réussissent ou ne parviennent pas à reculer; 2. Les attributs acides comprennent l'atomicité, la cohérence, l'isolement et la persistance; 3. Les déclarations qui contr?lent manuellement les transactions sont StartTransaction, Commit and Rollback; 4. Les quatre niveaux d'isolement incluent la lecture non engagée, la lecture soumise, la lecture reproductible et la sérialisation; 5. Utilisez correctement les transactions pour éviter le fonctionnement à long terme, désactiver les validations automatiques et gérer raisonnablement les verrous et les exceptions. Grace à ces mécanismes, MySQL peut obtenir une forte fiabilité et un contr?le simultané.

Le réglage des jeux de caractères et des règles de collation dans MySQL est crucial, affectant le stockage des données, l'efficacité de la requête et la cohérence. Premièrement, le jeu de caractères détermine la gamme de caractères storable, telle que UTF8MB4 prend en charge les chinois et les emojis; Les règles de tri contr?lent la méthode de comparaison des caractères, telle que UTF8MB4_UNICODE_CI est sensible à la casse, et UTF8MB4_BIN est une comparaison binaire. Deuxièmement, le jeu de caractères peut être défini à plusieurs niveaux de serveur, de base de données, de table et de colonne. Il est recommandé d'utiliser UTF8MB4 et UTF8MB4_UNICODE_CI de manière unifiée pour éviter les conflits. En outre, le problème du code brouillé est souvent causé par des jeux de caractères incohérents de connexions, de stockage ou de terminaux de programme, et doit être vérifié par calque par calque et définir uniformément. De plus, les ensembles de caractères doivent être spécifiés lors de l'exportation et de l'importation pour éviter les erreurs de conversion

La fa?on la plus directe de se connecter à la base de données MySQL consiste à utiliser le client de la ligne de commande. Entrez d'abord le nom d'utilisateur MySQL-U -P et entrez correctement le mot de passe pour entrer l'interface interactive; Si vous vous connectez à la base de données distante, vous devez ajouter le paramètre -H pour spécifier l'adresse h?te. Deuxièmement, vous pouvez directement passer à une base de données spécifique ou exécuter des fichiers SQL lors de la connexion, tels que le nom de la base de données MySQL-U Username-P ou le nom de la base de données MySQL-U Username-P-P

Pour configurer la réplication ma?tre-esclave asynchrone pour MySQL, suivez ces étapes: 1. Préparez le serveur ma?tre, activez les journaux binaires et définissez un serveur unique, créez un utilisateur de réplication et enregistrez l'emplacement du journal actuel; 2. Utilisez MySQLDump pour sauvegarder les données de la bibliothèque ma?tre et l'importez-les au serveur esclave; 3. Configurez le serveur-ID et le log-log du serveur esclave, utilisez la commande Changemaster pour vous connecter à la bibliothèque ma?tre et démarrer le thread de réplication; 4. Vérifiez les problèmes communs, tels que le réseau, les autorisations, la cohérence des données et les conflits d'auto-augmentation, et surveiller les retards de réplication. Suivez les étapes ci-dessus pour vous assurer que la configuration est terminée correctement.

Les CTES sont une fonctionnalité introduite par MySQL8.0 pour améliorer la lisibilité et la maintenance des requêtes complexes. 1. CTE est un ensemble de résultats temporaire, qui n'est valable que dans la requête actuelle, a une structure claire et prend en charge les références en double; 2. Comparé aux sous-requêtes, le CTE est plus lisible, réutilisable et prend en charge la récursivité; 3. Le CTE récursif peut traiter les données hiérarchiques, telles que la structure organisationnelle, qui doit inclure des requêtes initiales et des pièces de récursivité; 4. Les suggestions d'utilisation incluent l'évitement de l'abus, la dénomination des spécifications, la prête d'attention aux performances et aux méthodes de débogage.
