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
Partager