Précédent   Forum des professionnels en informatique > Bases de données > PostgreSQL
PostgreSQL Forum PostgreSQL. Avant de poster -> F.A.Q PostGreSQL Tutoriels PostGreSQL
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 24/02/2005, 16h36   #1
Invité de passage
 
Inscription : janvier 2005
Messages : 4
Détails du profil
Informations forums :
Inscription : janvier 2005
Messages : 4
Points : 2
Points : 2
Par défaut [debutant]detection des contraintes

bonjour
je débute sous Postgres et php.
je souhaite réaliser un 'viewer' de base de données le plus portable possible.
j'arrive actuellement à determiner toutes les tables d'une base, tous les champs de toutes les tables et leur contenus.......mon code est très portable puisque seul change les paramètres de connections pour les bases sous postgres.
Maintenant je voudrai dans le cas ou je demande d'afficher les valeurs de 2 tables :
ex tables 1 et la tables 2 imaginons que la table 2 contiennent en clé étrangère la clé primaire de la table 1, je ne veux pas afficher deux champs qui sont en fait parfaitement identiques.
Donc je cherche à detecter les contraintes de chaques tables , il me semble qu'il faut utiliser pg_constraint, mais je ne comprends pas comment!
si quelqu'un peut prendre quelque minutes pour m'expliquer il aura droit à mon éternel reconnaissance
jf
jeff_13 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/02/2005, 10h51   #2
Membre émérite
 
Avatar de hpalpha
 
Inscription : mars 2002
Messages : 770
Détails du profil
Informations forums :
Inscription : mars 2002
Messages : 770
Points : 833
Points : 833
Bonjour,
j'ai parcouru ton probleme très rapidement, et j'ai cherché dans mes archives des requetes que j'avais fait il y a quelque temps, ca ne te donne pas la réponse exacte à ta question mais en étudiant le fonctionnement, je pense que tu trouveras, c'est toujours sensiblement la meme chose :

Code :
1
2
3
4
5
/* Affichage des tables du schema monschema */
SELECT c.relname
FROM pg_catalog.pg_namespace AS n INNER JOIN pg_catalog.pg_class AS c ON (n.oid = c.relnamespace)
WHERE n.nspname = 'monschema'
AND c.relkind = 'r'::char;
Code :
1
2
3
4
5
6
7
8
/* Affichage des champs de la table matable du schema monschema  */
SELECT attname
FROM pg_catalog.pg_namespace AS n
INNER JOIN pg_catalog.pg_class AS c ON (n.oid = c.relnamespace)
INNER JOIN pg_catalog.pg_attribute AS a ON (c.oid=a.attrelid)
WHERE n.nspname =  'monschema  '
AND c.relkind = 'r'::char
AND c.relname = 'matable'
Code :
1
2
3
4
5
/* Affichage des fonctions du schema monschema */
SELECT c.proname
FROM pg_catalog.pg_namespace AS n
INNER JOIN pg_catalog.pg_proc AS c ON (n.oid = c.pronamespace)
WHERE n.nspname = 'monschema ';
Code :
1
2
3
4
5
6
7
8
/* Affichage des trigger de la table matable du schema monschema  */
SELECT g.tgname
FROM pg_catalog.pg_namespace AS n
INNER JOIN pg_catalog.pg_class AS c ON (n.oid = c.relnamespace)
INNER JOIN pg_catalog.pg_trigger AS g ON (c.oid=g.tgrelid)
WHERE n.nspname =  'monschema'
AND c.relkind = 'r'::char
AND c.relname = 'matable';
Bonne chance, et n'hésite pas à nous donner ta solution
hpalpha est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/02/2005, 11h01   #3
Invité de passage
 
Inscription : janvier 2005
Messages : 4
Détails du profil
Informations forums :
Inscription : janvier 2005
Messages : 4
Points : 2
Points : 2
super!

je devrais bien avancer avec ça !!
quand j'arrive à quelque chose je vous le dis!
jf
jeff_13 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 20h58.


 
 
 
 
Partenaires

Hébergement Web