IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PL/SQL Oracle Discussion :

Recherche d'une valeur dans une table


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Avril 2006
    Messages
    181
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 181
    Par défaut Recherche d'une valeur dans une table
    bonjour,

    je suis debutant en PL/SQL, et j'ai besoin d'un traitement.

    j'ai deux table A et B, dans la table A y'a des enregistrements et ou la premiere colonne peut contenir plusieurs valeurs, et dans la table B une seule colonne qui ne contient que deux valeurs disant "AA" et "BB".

    jusqu'a maintenant j'ai fais un curseur qui me retour tout l'enregistrement de la table A, et j'ai besoin qu'a chauqe fois qu'il va retourner (a travers le curseur) la valeur de la premiere colonne de la table A, il va chercher si cette valeur est existante dans la colonne de la table B.

    est ce que quelqu'un peut me dire comment je peux faire cela?

    voila le code que j'ai ecris jusqu'a maintenant, et qui ne marche pas:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
     
    DECLARE
    Cursor c_ligne_enrg is
    select Colonne1 from A;
     
    ligne_enrg c_ligne_enrg%rowtype;                           
     
    Begin               
     
        for ligne_enrg in c_ligne_enrg loop
            if ligne_enrg.Colonne1 in (select Colonne11 from B) then  
     
                DBMS_OUTPUT.PUT_LINE('C OK');
     
            else
                DBMS_OUTPUT.PUT_LINE('C KO');
            end if;
        end loop;
    end;

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Avec une simple requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT A.Colonne1,
           case when B.Colonne11 is null then 'C KO' else 'C OK' end as result
      FROM A
           left outer join B
             on B.Colonne11 = A.Colonne1;

  3. #3
    Membre confirmé
    Inscrit en
    Avril 2006
    Messages
    181
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 181
    Par défaut
    ce que je veux faire, c'est que pour chaque valeur de colonne1 de la table A, faire un test avec if pour voir si cette valeur existe dans colonne11 de la table B, si oui faire un traitement 1 sinon faire un traitement 2.
    sachant que la valeur de colonne 1 on la reccupere a travers un curseur.

  4. #4
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 953
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 953
    Par défaut
    Pas besoin d'un double curseur, utilise la requête de Waldar :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    begin
    for c in (SELECT A.Colonne1,
           		case when B.Colonne11 IS NULL then 'KO' else 'OK' end AS result
      	FROM A
           	LEFT OUTER JOIN B
             ON B.Colonne11 = A.Colonne1)
    loop
    	if (c.result = 'OK') then 
    		--traitement1
    	else
    		--tratement2
    	end if;
    end loop;
    end;

  5. #5
    Membre confirmé
    Inscrit en
    Avril 2006
    Messages
    181
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 181
    Par défaut
    D'accord, merci bcppp a vous deux

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 1
    Dernier message: 13/04/2015, 11h17
  2. Réponses: 8
    Dernier message: 28/11/2011, 11h40
  3. Réponses: 2
    Dernier message: 22/04/2008, 16h21
  4. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48
  5. Réponses: 1
    Dernier message: 25/09/2006, 17h15

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo