PL / SQL - Enregistrements
Dans ce chapitre, nous aborderons les enregistrements en PL / SQL. UNErecordest une structure de données qui peut contenir des éléments de données de différents types. Les enregistrements se composent de différents champs, similaires à une ligne d'une table de base de données.
Par exemple, vous souhaitez garder une trace de vos livres dans une bibliothèque. Vous souhaiterez peut-être suivre les attributs suivants pour chaque livre, tels que le titre, l'auteur, le sujet, l'ID du livre. Un enregistrement contenant un champ pour chacun de ces éléments permet de traiter un LIVRE comme une unité logique et vous permet d'organiser et de mieux représenter ses informations.
PL / SQL peut gérer les types d'enregistrements suivants -
- Table-based
- Enregistrements basés sur le curseur
- Enregistrements définis par l'utilisateur
Enregistrements basés sur des tables
L'attribut% ROWTYPE permet à un programmeur de créer table-based et cursorbased records.
L'exemple suivant illustre le concept de table-basedrecords. Nous utiliserons la table CUSTOMERS que nous avons créée et utilisée dans les chapitres précédents -
DECLARE
customer_rec customers%rowtype;
BEGIN
SELECT * into customer_rec
FROM customers
WHERE id = 5;
dbms_output.put_line('Customer ID: ' || customer_rec.id);
dbms_output.put_line('Customer Name: ' || customer_rec.name);
dbms_output.put_line('Customer Address: ' || customer_rec.address);
dbms_output.put_line('Customer Salary: ' || customer_rec.salary);
END;
/
Lorsque le code ci-dessus est exécuté à l'invite SQL, il produit le résultat suivant -
Customer ID: 5
Customer Name: Hardik
Customer Address: Bhopal
Customer Salary: 9000
PL/SQL procedure successfully completed.
Enregistrements basés sur le curseur
L'exemple suivant illustre le concept de cursor-basedrecords. Nous utiliserons la table CUSTOMERS que nous avons créée et utilisée dans les chapitres précédents -
DECLARE
CURSOR customer_cur is
SELECT id, name, address
FROM customers;
customer_rec customer_cur%rowtype;
BEGIN
OPEN customer_cur;
LOOP
FETCH customer_cur into customer_rec;
EXIT WHEN customer_cur%notfound;
DBMS_OUTPUT.put_line(customer_rec.id || ' ' || customer_rec.name);
END LOOP;
END;
/
Lorsque le code ci-dessus est exécuté à l'invite SQL, il produit le résultat suivant -
1 Ramesh
2 Khilan
3 kaushik
4 Chaitali
5 Hardik
6 Komal
PL/SQL procedure successfully completed.
Enregistrements définis par l'utilisateur
PL / SQL fournit un type d'enregistrement défini par l'utilisateur qui vous permet de définir les différentes structures d'enregistrement. Ces enregistrements se composent de différents champs. Supposons que vous souhaitiez garder une trace de vos livres dans une bibliothèque. Vous souhaiterez peut-être suivre les attributs suivants pour chaque livre -
- Title
- Author
- Subject
- ID du livre
Définition d'un enregistrement
Le type d'enregistrement est défini comme -
TYPE
type_name IS RECORD
( field_name1 datatype1 [NOT NULL] [:= DEFAULT EXPRESSION],
field_name2 datatype2 [NOT NULL] [:= DEFAULT EXPRESSION],
...
field_nameN datatypeN [NOT NULL] [:= DEFAULT EXPRESSION);
record-name type_name;
L'enregistrement de livre est déclaré de la manière suivante -
DECLARE
TYPE books IS RECORD
(title varchar(50),
author varchar(50),
subject varchar(100),
book_id number);
book1 books;
book2 books;
Accès aux champs
Pour accéder à n'importe quel champ d'un enregistrement, nous utilisons le point (.)opérateur. L'opérateur d'accès aux membres est codé comme un point entre le nom de la variable d'enregistrement et le champ auquel nous souhaitons accéder. Voici un exemple pour expliquer l'utilisation de record -
DECLARE
type books is record
(title varchar(50),
author varchar(50),
subject varchar(100),
book_id number);
book1 books;
book2 books;
BEGIN
-- Book 1 specification
book1.title := 'C Programming';
book1.author := 'Nuha Ali ';
book1.subject := 'C Programming Tutorial';
book1.book_id := 6495407;
-- Book 2 specification
book2.title := 'Telecom Billing';
book2.author := 'Zara Ali';
book2.subject := 'Telecom Billing Tutorial';
book2.book_id := 6495700;
-- Print book 1 record
dbms_output.put_line('Book 1 title : '|| book1.title);
dbms_output.put_line('Book 1 author : '|| book1.author);
dbms_output.put_line('Book 1 subject : '|| book1.subject);
dbms_output.put_line('Book 1 book_id : ' || book1.book_id);
-- Print book 2 record
dbms_output.put_line('Book 2 title : '|| book2.title);
dbms_output.put_line('Book 2 author : '|| book2.author);
dbms_output.put_line('Book 2 subject : '|| book2.subject);
dbms_output.put_line('Book 2 book_id : '|| book2.book_id);
END;
/
Lorsque le code ci-dessus est exécuté à l'invite SQL, il produit le résultat suivant -
Book 1 title : C Programming
Book 1 author : Nuha Ali
Book 1 subject : C Programming Tutorial
Book 1 book_id : 6495407
Book 2 title : Telecom Billing
Book 2 author : Zara Ali
Book 2 subject : Telecom Billing Tutorial
Book 2 book_id : 6495700
PL/SQL procedure successfully completed.
Enregistrements en tant que paramètres de sous-programme
Vous pouvez transmettre un enregistrement en tant que paramètre de sous-programme comme vous transmettez toute autre variable. Vous pouvez également accéder aux champs d'enregistrement de la même manière que vous avez accédé dans l'exemple ci-dessus -
DECLARE
type books is record
(title varchar(50),
author varchar(50),
subject varchar(100),
book_id number);
book1 books;
book2 books;
PROCEDURE printbook (book books) IS
BEGIN
dbms_output.put_line ('Book title : ' || book.title);
dbms_output.put_line('Book author : ' || book.author);
dbms_output.put_line( 'Book subject : ' || book.subject);
dbms_output.put_line( 'Book book_id : ' || book.book_id);
END;
BEGIN
-- Book 1 specification
book1.title := 'C Programming';
book1.author := 'Nuha Ali ';
book1.subject := 'C Programming Tutorial';
book1.book_id := 6495407;
-- Book 2 specification
book2.title := 'Telecom Billing';
book2.author := 'Zara Ali';
book2.subject := 'Telecom Billing Tutorial';
book2.book_id := 6495700;
-- Use procedure to print book info
printbook(book1);
printbook(book2);
END;
/
Lorsque le code ci-dessus est exécuté à l'invite SQL, il produit le résultat suivant -
Book title : C Programming
Book author : Nuha Ali
Book subject : C Programming Tutorial
Book book_id : 6495407
Book title : Telecom Billing
Book author : Zara Ali
Book subject : Telecom Billing Tutorial
Book book_id : 6495700
PL/SQL procedure successfully completed.