Php5 - couche d'abstraction sgbd

Soyez le premier à donner votre avis sur cette source.

Vue 8 244 fois - Téléchargée 859 fois


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 / Exemple :


<?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.
}

}

Codes Sources

A voir également

Ajouter un commentaire Commentaires
pifou25
Messages postés
144
Date d'inscription
lundi 13 octobre 2003
Statut
Membre
Dernière intervention
21 décembre 2014

21 déc. 2014 à 22:29
Bonjour,
pourquoi avoir utilisé des classes abstraites plutot qu'une interface ? en tout cas c'est une excellente idée et je tente de l'appliquer pour pouvoir utiliser indiféremment mysql, mysqli ou pdo.
Gaelcediene
Messages postés
3
Date d'inscription
mardi 10 mai 2005
Statut
Membre
Dernière intervention
7 février 2007

7 févr. 2007 à 17:00
Vraiment bien ton code. Je l'ai simplifié légèrement puis j'ai créé une classe pour postgresql. Et avec un peu de bidouillage, tout marche impeccablement bien.
Juste une chose : ne pas oublier que pour postgresql, il faut mettre l'hôte, le port, et la base de données dans la string pour se connecter. Donc on met juste un protected function private_selectdb() {
return TRUE;
}
Sinon, c'est le seul petit tru qui risquait de poser problème.
cs_tataye
Messages postés
21
Date d'inscription
jeudi 30 janvier 2003
Statut
Membre
Dernière intervention
30 juin 2009

20 août 2006 à 18:31
Bonjour,

Y-a-t'il une erreur dans les sources ?

Quelle que soit la méthode utilisée pour faire une requête, j'ai systématiquement comme erreur Fatal error: Call to undefined method mysql::fetchrow() ...
Amistrad
Messages postés
9
Date d'inscription
samedi 3 juin 2006
Statut
Membre
Dernière intervention
14 juin 2006

14 juin 2006 à 10:05
Salut,

En fait il y a quand meme quelque chose.

J'ai des difficultés avec la class dbInterface, je comprend pas bien son fonctionnement, et lorsque j'essaye d'instancier la class mysql il me dit : "
Fatal error: Cannot redeclare class dbinterface in C:\wamp\www\Class\db\b2database.php on line 2"

Si quelqu'un sait pourquoi, en attendant j'essaie de me connecter a mysql
merci

PS: je peux pas supprimer les deux messages précédents qui ne servent a rien... :)
Amistrad
Messages postés
9
Date d'inscription
samedi 3 juin 2006
Statut
Membre
Dernière intervention
14 juin 2006

13 juin 2006 à 14:43
bon bah il semblerait que j'ai poser une question avant de chercher.. sorry elle est bien la.
Afficher les 15 commentaires

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.