Accueil > > > PHP5 - COUCHE D'ABSTRACTION SGBD
PHP5 - COUCHE D'ABSTRACTION SGBD
Information sur la source
Description
Voila, je re-update un peu le code parce que y'a quand même de la modification (pis ca permet à ceux qui ne vont jamais dans les updates de codes de le voir étant donné que ma classe est désormais un peu plus aboutis qu'avant ! ).
Y'a quoi donc dans tout ca ?
Une classe d'abstraction pour n'importe quel SGBD possible. J'ai comme exemple MySQL et PostGreSQL. Vous verrez comme il est simpliste d'adapter le code pour n'importe quelle base de donnée (un héritage tout ce qu'il y a de plus simple, et peut être une ou deux surcharges).
Source
- <?php
- // Alors comment ca marche ?
- // D'abord on instancie la classe.
-
- try {
- $db = dbInterface::GetInstance('mysql', 'mysql');
- } catch ( Exception $e ) {
- die ( $e->getmessage() );
- }
-
- // Changer une option ?
- $db->set_option('ESCAPE_STRING', FALSE);
-
- // Faire une requète ?
- $xx = 'ezprze';
- try {
- $db->prepare("SELECT x,y,z FROM table WHERE xx = '{1}' ", $xx);
- $db->query();
- $data = $db->fetchrow();
- if ( $data[0] === '1' ) {
- // suite...
- } else {
- // sinon ...
- }
-
- } catch ( db_exception $e ) {
- $e->die_on_error();
- }
- // L'ancienne méthode marche aussi !
- // $sql = "SELECT...";
- // $query = $db->query($sql);
- // $data = $db->fetchrow($query);
-
- ?>
<?php
// Alors comment ca marche ?
// D'abord on instancie la classe.
try {
$db = dbInterface::GetInstance('mysql', 'mysql');
} catch ( Exception $e ) {
die ( $e->getmessage() );
}
// Changer une option ?
$db->set_option('ESCAPE_STRING', FALSE);
// Faire une requète ?
$xx = 'ezprze';
try {
$db->prepare("SELECT x,y,z FROM table WHERE xx = '{1}' ", $xx);
$db->query();
$data = $db->fetchrow();
if ( $data[0] === '1' ) {
// suite...
} else {
// sinon ...
}
} catch ( db_exception $e ) {
$e->die_on_error();
}
// L'ancienne méthode marche aussi !
// $sql = "SELECT...";
// $query = $db->query($sql);
// $data = $db->fetchrow($query);
?>
Conclusion
Y'a encore quelques options que j'ai pas renseigné, mais les noms veulent tout dire ! Je metterai un peu plus de documentation un peu plus tard.
Si y'a de l'optimisation à faire, je suis preneur :)
J'ai ajouté un multiton via la classe dbInterface. Ca permet d'éviter ce que l'ancienne classe faisait : Ouvrir une nouvelle connection pour rien.
Résultat ? J'ai gagné mes 9ms que je perdais avant... ! Je suis donc aussi rapide qu'une connection via fonction.
Pour récupérer votre connection dans une autre classe, il suffit de faire :
<?php
class x {
public function __construct() {
$this->db = dbInterface::GetInstance('mysql'); // Si vous avez déja instancier la classe avec comme nom : mysql;
// OU
$this->db = dbInterface::GetInstance('mysql', 'mysql'); // Si vous n'êtes pas sur, il établira la connection automatiquement si elle n'existe pas.
}
}
Historique
- 10 janvier 2006 14:56:01 :
- Ajout d'une petite classe multi BDD
- 16 janvier 2006 18:35:27 :
- Ajout d'un multiton pour optimiser les perfs. Amélioration et clarification du code.
Oubli cependant du mode de bench... !
- 16 janvier 2006 18:37:48 :
- J'ai oublié le ::GetInstance :o
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
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
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
j'ai un problem sql et class [ par theyas ]
salut j un problem ou partie de class news je vais ajouté un condition sql(where)pour afficher seulment les enregistrement qui porte le nom champ(nom_
[POO] Une classe dans une classe [ par Mrreivax ]
Bonsoir.Et bien voila. J'ai créé une classe de gestion des images.J'ai par la suité créé une autre classe de gestion de banières.Mais, cette dernière
Projet PHP5/SQL [ par alexgeek ]
Bonjour,Je suis débutante en PHP et j'ai un projet en php my sql à faire puisque je suis en stage, si quelqu'un pouais m'aider à le faire je lui serai
Problème de variables en dehors d'une class [ par yukimura27 ]
Bonjour à tous, J'ai un problème pour utiliser une variable en dehors de ma class. Voici mon code: class pouet { public function SelectAll () {
PHP5 SQL TIME [ par ftsitoha ]
Bonjour les amies !!! Question web PHP- SQL -TIME? J’aimerai bien connaître l’erreur de ces 2 scriptes, mon attribue n’est pas ti
comment crypter mon mot de passe [ par msi079 ]
salut . j'ai un code qui marche mais mon problème est que le mot de passe n'est pas crypté . je suis débutant en php je sais pas comment m'y prendre.
connexion BDD SQL Server [ par akkaoui ]
Salut tout le monde! J'essaie de se connecter à une base de donnée SQL server via un script php pour mon projet Donc j'utilise le code suivant Code
|
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
|