Précédent   Forum des professionnels en informatique > Bases de données > Oracle > SQL
SQL Forum d'entraide sur le SQL pour Oracle
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 27/04/2011, 10h13   #1
Membre à l'essai
 
Homme Coul Baba
Inscription : novembre 2009
Messages : 60
Détails du profil
Informations personnelles :
Nom : Homme Coul Baba

Informations forums :
Inscription : novembre 2009
Messages : 60
Points : 21
Points : 21
Par défaut Sélection générique de colonnes

Bonjour à tous,

Je suis débutant et j'aimerai savoir s'il y a une méthode permettant de sélectionner les valeurs d'un ensemble de colonnes commençant par une chaîne de caractères donnée.

Par exemple dans une table :
Personne (nom, prenom, nom_pere, nom_mere, nomprenfant, nomdeuxenfant)
Pour sélectionner les valeurs de tous les noms, on fait:
Code sql :
1
2
SELECT nom, nom_pere, nom_mere, nomprenfant, nomdeuxenfant
  FROM personne;
Mais vu que dans ma table j'ai beaucoup de colonnes qui commence par cette
chaîne, je veux trouver un moyen générique pour ne pas taper le nom de chaque colonne concernée.

Merci d'avance pour ceux qui m'éclaireront sur ce sujet.
alamako est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/04/2011, 11h44   #2
Candidat au titre de Membre du Club
 
Inscription : juin 2009
Messages : 28
Détails du profil
Informations forums :
Inscription : juin 2009
Messages : 28
Points : 11
Points : 11
Salut

Tu vas devoir construire une chaine de caractéres que tu vas remplir avec les nom de tes champs et utilisé EXECUTE IMMEDIATE ensuite.

Code SQL :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
 DECLARE
  v_statmt  VARCHAR2(512 BYTE);
BEGIN
  v_statmt := 'SELECT ';
 
  FOR r_nomcol IN ( SELECT column_name 
                    FROM all_tab_columns 
                    WHERE table_name = 'PERSON' 
                    AND column_name LIKE 'NOM%')
  LOOP
    v_statmt := || r_nomcol.column_name;
  END LOOP;
 
  v_statmt := v_statmt || ' FROM PERSON';
 
  EXECUTE IMMEDIATE v_statmt;
END;

Mais ça devient du PL/SLQ et plus une "simple" requête SQL.

J'espère que ça aide
diplomegalo est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/04/2011, 15h32   #3
Membre à l'essai
 
Homme Coul Baba
Inscription : novembre 2009
Messages : 60
Détails du profil
Informations personnelles :
Nom : Homme Coul Baba

Informations forums :
Inscription : novembre 2009
Messages : 60
Points : 21
Points : 21
Merci de votre intervention, je vais essayer ce code, surtout je volais savoir s'il y a une possibilité en SQL simple.
alamako est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/04/2011, 17h26   #4
McM
Expert Confirmé Sénior
 
Inscription : juillet 2003
Messages : 3 437
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 3 437
Points : 4 173
Points : 4 173
Non, il n'y a pas cette possibilité en sql.
__________________
More Code : More Bugs. Less Code : Less Bugs
McM est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/04/2011, 18h05   #5
Membre à l'essai
 
Homme Coul Baba
Inscription : novembre 2009
Messages : 60
Détails du profil
Informations personnelles :
Nom : Homme Coul Baba

Informations forums :
Inscription : novembre 2009
Messages : 60
Points : 21
Points : 21
Merci pour ces infos.
alamako est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 08h07.


 
 
 
 
Partenaires

Hébergement Web