Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD
PHP & SGBD Forum d'entraide sur les SGBD avec PHP. Avant de poster : FAQ BDD, toutes les FAQ PHP, cours BDD et sources BDD
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 25/04/2007, 17h07   #1
Futur Membre du Club
 
Inscription : décembre 2006
Messages : 45
Détails du profil
Informations forums :
Inscription : décembre 2006
Messages : 45
Points : 15
Points : 15
Par défaut [SQL] 1 requête, 2 SGBD

salut
j'aimerais savoir s'il est possible d'ecrire une requete qui utilise 2 tables dont chaqune appartient à un sgbd
par exemple:
$con1=mysql_connect....
$con2=pg_connect.....

$req="insert into A values B" ,avec A une table d'une bd MySQL et B une table d'une bd PostgreSQL
Merci d'avance ,cordialement.
walid0577 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/04/2007, 18h13   #2
Membre éclairé
 
Inscription : juillet 2003
Messages : 338
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 338
Points : 339
Points : 339
Si tu veux faire ça, il me semble qu'il faut deux étapes, et c'est à partir d'une base que tu insères. Il existe peut être des outils pour faire cela d'une manière transparente mais SQL ne semble pas capable de le faire...
En revanche tu peux ouvrir deux connexions sur deux bases dans le même script
voir ce post
tatareau est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/04/2007, 10h08   #3
Membre habitué
 
Avatar de Shinji62
 
Inscription : novembre 2006
Messages : 135
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 135
Points : 133
Points : 133
Bonjour,
Crée des classes, une classe pour ta DB1 et une classe pour ta DB2, ou une seule class.

Class DB {
ETcccc........
}

puis peu importe ton SGBD.
Shinji62 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/04/2007, 20h22   #4
Membre éclairé
 
Inscription : juillet 2003
Messages : 338
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 338
Points : 339
Points : 339
Shinji62
Citation:
Crée des classes, une classe pour ta DB1 et une classe pour ta DB2, ou une seule class.
Et elles font quoi ces classes?
Si l'idée serait une classe 'abstraite' qui servirai pour faire une instanciation sur deux bases de données (prémice d'héritage multiple?), cela ne resout pas le fait que dans une même requête notre ami walid0577 veut deux tables au moins dans au moins deux bases de données distinctes, qui plus aient de type différente. C'est ce que j'ai compris. Vu que SQL s'execute dans un SGBD, ça me semble dur d'ailleurs les implémentations SQL sont différentes dans les deux SGBD.
Enfin si tu as un peu de code, ou de la doc (ref , url) , ça m'interesse.
tatareau est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/04/2007, 21h11   #5
Futur Membre du Club
 
Inscription : décembre 2006
Messages : 45
Détails du profil
Informations forums :
Inscription : décembre 2006
Messages : 45
Points : 15
Points : 15
voici une portion de code, je veux faire une fonction qui à chaque mis à jour d'une table d'un sgbd applique la meme màj pour la table qui lui est similaire dans le 2eme sgbd:

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
 private function updateDB()
        {
       	// on se connecte à MySQL on sélectionne la base
        $dbmy = mysql_connect($localhost, $root, $'') or die ("Impossible de se connecter : " . mysql_error()); 
        mysql_select_db($sugarcrm,$dbmy);
 
		// on se connecte à PostgreSQL et on selectionne la base
		$dbpg = pg_connect("host=localhost port=5432 dbname=terp user=tinypg password=password")or die ("Impossible de se connecter : " . pg_last_error());
 
 
 
 //requete 
		$query1 = 'CREATE TRIGGER account_my AFTER INSERT OR DELETE OR UPDATE ON account FOR EACH ROW
           BEGIN
 
           END;';
		$query2 = 'CREATE TRIGGER account_pg AFTER INSERT OR DELETE OR UPDATE ON account FOR EACH ROW
           BEGIN
 
           END;';
 
 
		$result1 = mysql_query($dbmy,$query1);
		$result2 = pg_query($dbpg,$query2);
 
        }
ce que je veux savoir c'est :
est ce possible d'ecrire ça:
$query1 = 'CREATE TRIGGER account_my AFTER INSERT OR DELETE OR UPDATE ON account FOR EACH ROW
BEGIN
INSERT INTO accouny_pg .....
END;';

sinon j'ai une autre idée :chaque trigger crée une vue de la table qu'il va traiter et puis on utilise fetch pour avoir le contenue de la table et on l'insere dans l'autre table,mais le probleme est que d'apres ce que je sais mysql_fetch_row et pg_fetch_row ne donnent pas le meme resultat et aussi il n'y a pas d'equivalent à pg_insert pour mysql.
"les vues servent pour s'assurer que le traitement commence apres le declenchement d'un trigger"


il y aurait peut etre du n'importe quoi dans tout ça (je suis encore etudiant et débutant en php)
cordialement.
walid0577 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 01h53.


 
 
 
 
Partenaires

Hébergement Web