Accueil > > > TENTATIVE D'APPROCHE D'UN MODÈLE CRUD : UTILISATION D'UNE CLASSE SGBD
TENTATIVE D'APPROCHE D'UN MODÈLE CRUD : UTILISATION D'UNE CLASSE SGBD
Information sur la source
Description
Bonjour à tous, Après une première approche complètement ratée (voir : http://www.phpcs.com/code.aspx?ID=42628), je propose une autre solution qui est carrément plus performante (c'était pas dificile de faire mieux). En meme temps, cette source est en php5, finalement j'ai décidé de migrer, donc ca aide. Bref, qu'est-ce que vous allez trouver dedans : J'ai integré ma classe abstraite database ainsi que ma classe mysql pour la relation avec la base de donnée (qui à été fortement inspiré de celle de FhX, je l'avoue et lui remercie de ses bonnes sources), mais ca marche très bien avec ses sources ou avec les votres, il suffit d'adapter le code. Avec ces deux classes, vous trouverez une classe users, qui permet de faire la relation entre la classe base de donnée et une sortie éventuelle (découpage du code en architecture 3 tier, MVC)
Source
- <?PHP
- /**
- Voici la table à mettre pour l'exemple :
-
- DROP TABLE IF EXISTS `users`;
- CREATE TABLE IF NOT EXISTS `users` (
- `Uid` smallint(5) unsigned NOT NULL auto_increment,
- `Login` varchar(250) NOT NULL,
- `Passwd` varchar(250) NOT NULL,
- `Email` varchar(250) NOT NULL,
- `Website` varchar(250) NOT NULL,
- PRIMARY KEY (`Uid`)
- ) ENGINE=MyISAM DEFAULT CHARSET=latin1;
-
-
- **/
-
- require_once ("vars.php"); // On inclut le fichier contenant les principales variables
- require_once (DB_PATH."database.class.php"); // On inclut la classe abstraite
- require_once (DB_PATH.DB_MODEL.".class.php"); // et la classe mysql (dans ce cas)
-
- require_once (CLASS_PATH."users.class.php"); // et la classe utilisateur, pour l'exemple
-
- $users = new users (); // On instancie la clases utilisateur
-
- // A partir de ce moment, les actions vers la base de donnée deviennent très simples :
-
- // Pour ajouter un utilisateur :
- $users->addUser("login", "password", "email@domain.tld", "http://www.domain.tld");
-
- // Pour Modifier un utilisateur
- $users->modUser("Id", "new_login", "new_password", "new_email@domain.tld", "http://www.new_domain.tld");
-
- // Pour supprimer un utilisateur
- $users->delUser ("Id");
-
- // Pour lister les utilisateurs
- $users->listUsers();
- ?>
<?PHP
/**
Voici la table à mettre pour l'exemple :
DROP TABLE IF EXISTS `users`;
CREATE TABLE IF NOT EXISTS `users` (
`Uid` smallint(5) unsigned NOT NULL auto_increment,
`Login` varchar(250) NOT NULL,
`Passwd` varchar(250) NOT NULL,
`Email` varchar(250) NOT NULL,
`Website` varchar(250) NOT NULL,
PRIMARY KEY (`Uid`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;
**/
require_once ("vars.php"); // On inclut le fichier contenant les principales variables
require_once (DB_PATH."database.class.php"); // On inclut la classe abstraite
require_once (DB_PATH.DB_MODEL.".class.php"); // et la classe mysql (dans ce cas)
require_once (CLASS_PATH."users.class.php"); // et la classe utilisateur, pour l'exemple
$users = new users (); // On instancie la clases utilisateur
// A partir de ce moment, les actions vers la base de donnée deviennent très simples :
// Pour ajouter un utilisateur :
$users->addUser("login", "password", "email@domain.tld", "http://www.domain.tld");
// Pour Modifier un utilisateur
$users->modUser("Id", "new_login", "new_password", "new_email@domain.tld", "http://www.new_domain.tld");
// Pour supprimer un utilisateur
$users->delUser ("Id");
// Pour lister les utilisateurs
$users->listUsers();
?>
Conclusion
On peu biensur augmenter les capacités de la classe en y ajoutant des fonctions spécifiques. Ce que j'ai mis ici n'est juste qu'à titre d'exemple au niveau fonctionnalité, l'idée étant de faire une fonction pour chaques "actions" (je dirai meme requete, mais pas nécéssairement). Ensuite, afin de bien découper le travail, le plus interessant (à mon gout) est de faire une classe par table.
Je n'ai pas vu quelque chose de semblant sur le site, excepté la source de Masternico (http://www.phpcs.com/codes/CLASSE-ACCES-BASE-DONN EES_42649.aspx), mais qui n'utilisait pas une classe SGBD abstraite. C'est pour cela que je me suis lancé à la proposer.
Au niveau des fonctionnalités : La classe abstraite dispose d'un gestionnaire d'erreur (très simple) : Elle enregistre l'erreur retournée dans un tableau, si la variable _config["SHOW_ERROR"] est sur true, elle affichera l'erreur. Elle permet de faire les principales actions sur une base : query, free_result, last_id, fetch_* (=row, array, object), affected_rows
La classe mysql gèree les singleton. Pour le reste elle est dépendante de la classe abstraite
La classe users permet d'ajouter, modifier, supprimer et lister les utilisateurs. Une évolution qui pourrait être très interessante serait de faire une classe à part qui s'occuperait des actions principales : Ajouter, Modifier, Lister, Supprimer : et la on s'approcherai vraiment du modèle CRUD. (Create, Read, Update, Delete)
Au niveau des défauts : mes classes sont commentées (excepté la classe mysql, désolé :/) Et je ne suis pas sur de l'efficacité de la déclaration de la classe mysql. Je vous explique : Dans le fichier de config (vars.php), on spécifie le type de class sgbd (dans mon cas mysql) Dans la page index.php (celle dont le code source est juste ci-haut), je l'insère par un require_once (DB_PATH.DB_MODEL.".class.php"); Mais pour l'instancier, je le fait dans la classe users (je pourrai éventuellement le faire sur le fichier index.php) de cette manière :
eval ('$this->dblink = '.DB_MODEL.'::GetInstance();'); // et ensuite $this->dblink->Connect ();
Le fait que le modèle de sgbd soit dans une constante (ou même dans une variable), m'a bloqué, et je n'ai trouvé que cette solution. Si vous en voyez d'autres, je suis preneur !!
Voila, j'attends vos commentaires avec impatience :) Remarque : Contrairement à la précédente fois, je prendrais vraiment les commentaires envers ma classe comme avis et pas comme "attaque" simplement car ce coup je poste ma source pour avoir des avis, des modifications a effectuer. La dernière fois, j'esperais des commentaires sur le concept, non sur la classe :)
Historique
- 10 mai 2007 11:12:37 :
- Modification de $users->modUser("Id", "login", "password", "email@domain.tld", "http://www.domain.tld"); en $users->modUser("Id", "new_login", "new_password", "new_email@domain.tld", "http://www.new_domain.tld"); pour être plus explicite
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Class POO retourné le nom de l'objet [ par MeTh ]
Bonjour,Comment retourné le nom de l'objet déclaré?exemple :$monobjet = new GridR();comment recuperé $monobjet dans ma class?Merci
templates avec poo [ par lesnes ]
bonjours je reprogramme totalement mon site en poo et je souhaiterai utiliser les templates mais l'on ne peut pas faire appel a une class exterieur a
question sur redhat8 mysql [ par mohamedjayed ]
je veut installer le SGBD mysql sous redhat8 et je connait pas la procedure d'instalationet la configuration de ce sgbd est ce qui'il y a quelqu
Probleme en POO [ par pablor44 ]
Bonjour,alors voilà je vous explique mon probleme, je suis en train d'ecrire une classe en php pour mon site et je me retrouve dans la situation
Gestion membres via POO [ par FhX ]
Je me posais la question justement. Pour pouvoir faire une interface membre (donc : admin + membre + visiteur), dois-je faire ca en une seule classe ?
logiciel POO [ par kowal2205 ]
Je me pose la question de la création de mes classes dans un projet de taille moyenne car je ne trouve pas de logiciel à mon pied qui me per
Reflexion sur un schema de POO (gestion d'emploi du temps d'une UFR) [ par Franquito ]
Bonjour à tous ! Je dois réaliser un schema pour une application de programation orienté objet. L'application fait la gestion d'emploi du temps d'un
Comment ca marche cette petite bete? [ par craso ]
bonjour,en surfant, je suis tombé sur le site http://www.phpied.com/image-fun/ .Je souhaite qu'on m'explique comment trnsformer une image comme sur le
réécriture d'un script en POO, comment faire? [ par craso ]
Bonjour,j'ai développé cette petite application http://pipcorp.free.fr/Il s'agit d'une image clicable, le personnage centrale se positionne a l'endroi
[POO] Développer son Framework [ par Foxhive ]
Bonjour à tous, Cela fait longtemps que l'idée m'interesse mais j'ai jamais vraiment osé me jeter à l'eau. Mais là que je suis en vacance je me dis qu
|
Derniers Blogs
IMAGINE CUP 2012, MAKE A SIGN EN FINALEIMAGINE CUP 2012, MAKE A SIGN EN FINALE par junarnoalg
Voilà qui est fait, la nouvelle est officielle ! L'équipe belge "Make a Sign" va au pays des kangourous défendre son projet dans la catégorie Software Design. http://www.imaginecup.com/CompetitionsContent/Competition/WorldwideFinalists.aspx V...
Cliquez pour lire la suite de l'article par junarnoalg KINECT 1.5 IS OUT !KINECT 1.5 IS OUT ! par Vko
La version 1.5 du Kinect For Microsoft vient tout juste de sortir ! Plein de nouveautés: Tracking de squelette en Near Mode Détection en position assise Détection faciale avec un SDK dédié Documentation et des guideline (enfin) Un out...
Cliquez pour lire la suite de l'article par Vko LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) par richardc
Mise à jour des Web API du 14 Mai
Réservez dès maintenant votre journée du 20 juin pour le Windows Azure Dev Camp 2012 à Paris
Mise à jour de Team Foundation Service
MechCommander 2 sur Windows 8
Entity Framework 5 Release Candidate e...
Cliquez pour lire la suite de l'article par richardc REACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITERREACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITER par Groc
Une mauvaise utilisation de rx lors de l'écriture d'une couche d'accès à des services peut conduire à des cas embarassants avec des erreurs mal gérées, des appels qui ne partent lorsqu'ils le devraient, et même des résultats incorrects . le tout nuis...
Cliquez pour lire la suite de l'article par Groc SHAREPOINT BLOG SITE, PROBLèME D'ARCHIVESSHAREPOINT BLOG SITE, PROBLèME D'ARCHIVES par junarnoalg
Dernièrement, nous avons migré le site
myTIC
vers un nouveau serveur SharePoint 2010. Dans les contenus que nous vouloins récupérer, nous avions un certain nombre de blogs.
Nous avons utilisé les commandes Power...
Cliquez pour lire la suite de l'article par junarnoalg
Logiciels
sDEVIS-FACTURES vlPRO (8.1.0.3)SDEVIS-FACTURES VLPRO (8.1.0.3)sDEVIS-FACTURES vlPRO a été mis au point pour les particuliers, créateurs, entrepreneurs, artisa... Cliquez pour télécharger sDEVIS-FACTURES vlPRO 974 Application Server (12.2.4.6)974 APPLICATION SERVER (12.2.4.6)Développez de puissantes applications dans un environnement de 'cloud computing', clusterisé, séc... Cliquez pour télécharger 974 Application Server vPicture (1.4.2.1)VPICTURE (1.4.2.1)Avec vPicture, hébergez vos images facilement et rapidement.
vPicture est un utilitaire simple, ... Cliquez pour télécharger vPicture Easy-Planning (2.2.1.6)EASY-PLANNING (2.2.1.6)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté au... Cliquez pour télécharger Easy-Planning COM-BACKUP (2.0)COM-BACKUP (2.0)
COM-BACKUP est un logiciel de sauvegarde qui permet de planifier les sauvegardes de vos dossiers ...
Cliquez pour télécharger COM-BACKUP
|