Types de données composites Deux catégories de données composites : Enregistrements PL/SQL Ensembles PL/SQL Table INDEX BY VARRAY Les types de données composites contiennent des composantes internes
Enregistrements PL/SQL Composés d’un ou plusieurs champs de type scalaire, RECORD ou INDEX BY Différents des lignes d’une table de base de données Traitent un ensemble de champs comme une unité logique Permettent d’extraire une ligne de données à partir d’une table pour la traiter
Création d’un enregistrement Pour créer un enregistrement, il faut définir un type RECORD, puis déclarer des enregistrements de ce type. TYPE type_name IS RECORD (field_declaration [, field_declaration]…); Où field_declaration est : field_name {field_type | variable%TYPE |table.column%TYPE|table%ROWTYPE} [[NOT NULL] {:= | DEFAULT} expr]
Exemple TYPE emp_record_type IS RECORD (numemp number(6) not null := 100, nomemp emp.ename%TYPE, fonction varchar2(20), salaire number(10,2)); emp_record emp_record_type;
Exemple DECLARE TYPE personne IS RECORD (nom pilote.plnom%TYPE, prenom pilote.plprenom%TYPE, ville pilote.ville%TYPE, salaire pilote.salaire%TYPE); pl_record personne; BEGIN SELECT plnom,plprenom,ville,salaire INTO pl_record FROM PILOTE WHERE plnum = &numero_pilote; DBMS_OUTPUT.PUT_LINE(pl.prenom||’ ‘||upper(pl.nom)||’ ‘|| pl.ville||’ ‘||pl.salaire); END;
Attribut %ROWTYPE Permet de déclarer une variable à partir d’un ensemble de colonnes d’une table ou d’une vue de base de données. Doit être précédé du nom de la table de base de données. Les champs de l’enregistrement tirent leurs noms et leurs types de données des colonnes de la table ou de la vue. declare emp_record employe%ROWTYPE;
Attribut %ROWTYPE Il n’est pas nécessaire de connaitre le nombre et les types de données des colonnes de la table de base de données sous-jacente. Le nombre et les types des colonnes de la table de base de données sous-jacente peuvent être modifiés à l’exécution. L’attribut permet d’extraire une ligne avec l’instruction SELECT *
Exemple DEFINE emp_numero = 1812 DECLARE emp_rec emp%ROWTYPE; BEGIN SELECT * INTO emp_rec FROM emp WHERE empno = &emp_numero; INSERT INTO emp_retraite VALUES(emp_rec.empno,emp_rec.ename,emp_rec.job, emp_rec.mgr,emp_rec.hiredate,SYSDATE, emp_rec.sal,emp_rec.comm,emp_rec.dept); COMMIT; END;
Table INDEX BY Ces tables comportent 2 composants : Une clé primaire de type BINARY_INTEGER Une colonne de type scalaire ou RECORD Leur taille peut augmenter de façon dynamique, car elles ne présentent pas de contrainte.
Créer une table INDEX BY TYPE type_name IS TABLE OF {column_type | variable%TYPE |table.column%TYPE} [NOT NULL] |table%ROWTYPE [INDEX BY BINARY_INTEGER]; identifier type_name; TYPE ename_table_type IS TABLE OF employe.nomemp%TYPE INDEX BY BINARY_INTEGER; ename_table ename_table_type;
Créer une table INDEX BY DECLARE TYPE ename_table_type IS TABLE OF employe.nomemp%TYPE INDEX BY BINARY_INTEGER; TYPE dateemb_table_type IS TABLE OF employe.dateemb%TYPE ename_table ename_table_type; dateemb_table dateemb_table_type; BEGIN ename_table(1) := ‘AMALI’; dateemb_table(5) := SYSDATE + 7; IF ename_table.EXISTS(1) THEN INSERT INTO … … END; /
Méthodes des tables INDEX BY Les méthodes suivantes facilitent l’utilisation des tables INDEX BY : EXISTS COUNT FIRST and LAST PRIOR(indice) NEXT(indice) TRIM[(n)] DELETE[(n[,m)])] EXTEND(n) LIMIT
Table d’enregistrements INDEX BY Définir une variable TABLE avec un type de données PL/SQL admis. Déclarer une variable PL/SQL pour le stockage des informations d’un service. DECLARE TYPE serv_table_type IS TABLE OF service%ROWTYPE INDEX BY BINARY_INTEGER; serv_table serv_table_type; -- tout élément de la table serv_table est un enregistrement
Exemple SET SERVEROUTPUT ON DECLARE TYPE emp_table_type IS TABLE OF employe%ROWTYPE INDEX BY BINARY_INTEGER; my_emp_table emp_table_type; v_count number(3):=105; BEGIN FOR i IN 100..v_count LOOP select * INTO my_emp_table(i) from employe where numemp = i; END LOOP; FOR i IN my_emp_table.FIRST..my_emp_table.LAST dbms_output.put_line(my_emp_table(i).nomemp); END; /