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

Oracle Discussion :

Procédure de vérification avec deux manières


Sujet :

Oracle

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2013
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2013
    Messages : 16
    Points : 12
    Points
    12
    Par défaut Procédure de vérification avec deux manières
    bonjour tout le monde,
    svp , si c'est possible de m'aider dans ce problème ???

    je veux écrire de 2 manières différentes : 1- avec les exceptions, 2- avec les curseurs , une procédure qui permet de vérifier si une table contient ou non un champ. le nom de la table et le nom du champ sont passés en argument.
    je utilise ici la table all_tab_columns(Owner,Table_name, Column_name,...)

    voilà la solution que j'ai faite avec les curseurs, mais je ne sais pas si elle est correcte ou non ???

    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
    Create or replace Procedure verif(nomTab varchar2, champ varchar2) is
    Cursor c1 is select  * from all_tab_columns where Table_Name=nomTab  and column_name=champ;
    nbr Number(20) := 0;
    c2  all_tab_columns%Rowtype;
    Begin 
            open c1;
            LOOP
            fetch c1 in c2;
            nbr:=c1%rowcount;
            Exit when (c1%Notfound);
            END LOOP;
                if nbr>0 then
              DBMS_OUTPUT.PUT_Line(" le champs "|| champ||" existe dans la table "|| nomTable);
                else
             DBMS_OUTPUT.PUT_Line(" le champs "|| champ||" n'existe pas dans la table "|| nomTable);
             end if;
    end;
    /

    et si c'est possible de me dire comment faire cette vérification en utilisant les exceptions seulement ?
    et merci beaucoup

  2. #2
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Begin
      Select ... Into ... From ...
    Exception
      When NO_DATA_FOUND Then
        ...
    End;

Discussions similaires

  1. Faire une procédure stockée avec deux tables
    Par mister3957 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 17/03/2006, 13h54
  2. Procédure stockée avec deux paramètres ADO/ORACLE
    Par zanifu dans le forum Bases de données
    Réponses: 7
    Dernier message: 01/03/2006, 09h13
  3. Réponses: 10
    Dernier message: 10/06/2004, 16h20
  4. [VB6] procédure de vérification d'adresse mail ?
    Par ghohm dans le forum VB 6 et antérieur
    Réponses: 12
    Dernier message: 07/06/2004, 13h05
  5. [langage] split avec deux motifs (Newbie)
    Par Raumsog II dans le forum Langage
    Réponses: 2
    Dernier message: 07/06/2004, 09h31

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