पीएल / एसक्यूएल - रिकॉर्ड

इस अध्याय में, हम PL / SQL में रिकॉर्ड्स पर चर्चा करेंगे। एrecordएक डेटा संरचना है जो विभिन्न प्रकार के डेटा आइटम धारण कर सकती है। डेटाबेस तालिका की एक पंक्ति के समान रिकॉर्ड में विभिन्न फ़ील्ड शामिल हैं।

उदाहरण के लिए, आप लाइब्रेरी में अपनी पुस्तकों पर नज़र रखना चाहते हैं। आप प्रत्येक पुस्तक, जैसे शीर्षक, लेखक, विषय, पुस्तक आईडी के बारे में निम्नलिखित विशेषताओं को ट्रैक करना चाह सकते हैं। इन मदों में से प्रत्येक के लिए एक क्षेत्र युक्त एक रिकॉर्ड एक बुक को एक तार्किक इकाई के रूप में व्यवहार करने की अनुमति देता है और आपको बेहतर तरीके से इसकी जानकारी को व्यवस्थित करने और प्रतिनिधित्व करने की अनुमति देता है।

पीएल / एसक्यूएल निम्नलिखित प्रकार के रिकॉर्ड संभाल सकता है -

  • Table-based
  • कर्सर आधारित रिकॉर्ड
  • उपयोगकर्ता-परिभाषित रिकॉर्ड

तालिका-आधारित रिकॉर्ड

% ROWTYPE विशेषता प्रोग्रामर को बनाने में सक्षम बनाती है table-based तथा cursorbased रिकॉर्ड।

निम्नलिखित उदाहरण की अवधारणा को दर्शाता है table-basedरिकॉर्ड। हम पिछले अध्यायों में बनाए गए और उपयोग किए गए ग्राहक तालिका का उपयोग करेंगे -

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; 
/

जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Customer ID: 5 
Customer Name: Hardik 
Customer Address: Bhopal 
Customer Salary: 9000 
 
PL/SQL procedure successfully completed.

कर्सर-आधारित रिकॉर्ड

निम्नलिखित उदाहरण की अवधारणा को दर्शाता है cursor-basedरिकॉर्ड। हम पिछले अध्यायों में बनाए गए और उपयोग किए गए ग्राहक तालिका का उपयोग करेंगे -

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; 
/

जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

1 Ramesh 
2 Khilan 
3 kaushik 
4 Chaitali 
5 Hardik 
6 Komal  

PL/SQL procedure successfully completed.

उपयोगकर्ता-परिभाषित रिकॉर्ड

पीएल / एसक्यूएल एक उपयोगकर्ता-परिभाषित रिकॉर्ड प्रकार प्रदान करता है जो आपको विभिन्न रिकॉर्ड संरचनाओं को परिभाषित करने की अनुमति देता है। इन अभिलेखों में विभिन्न क्षेत्र शामिल हैं। मान लीजिए कि आप किसी लाइब्रेरी में अपनी पुस्तकों पर नज़र रखना चाहते हैं। आप प्रत्येक पुस्तक के बारे में निम्नलिखित विशेषताओं को ट्रैक करना चाहते हैं -

  • Title
  • Author
  • Subject
  • बुक आईडी

एक रिकॉर्ड को परिभाषित करना

रिकॉर्ड प्रकार को निम्न के रूप में परिभाषित किया गया है -

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;

पुस्तक रिकॉर्ड निम्नलिखित तरीके से घोषित किया गया है -

DECLARE 
TYPE books IS RECORD 
(title  varchar(50), 
   author  varchar(50), 
   subject varchar(100), 
   book_id   number); 
book1 books; 
book2 books;

खेतों तक पहुँच

किसी रिकॉर्ड के किसी भी क्षेत्र तक पहुँचने के लिए, हम डॉट का उपयोग करते हैं (.)ऑपरेटर। सदस्य एक्सेस ऑपरेटर को रिकॉर्ड चर नाम और उस क्षेत्र के बीच की अवधि के रूप में कोडित किया जाता है जिसे हम एक्सेस करना चाहते हैं। निम्नलिखित रिकॉर्ड के उपयोग की व्याख्या करने के लिए एक उदाहरण है -

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; 
/

जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

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.

सबप्रोग्राम पैरामीटर के रूप में रिकॉर्ड

जैसे ही आप किसी अन्य चर को पास करते हैं, आप सबप्रोग्राम पैरामीटर के रूप में एक रिकॉर्ड पारित कर सकते हैं। आप रिकॉर्ड फ़ील्ड को उसी तरह एक्सेस कर सकते हैं जैसे आपने उपरोक्त उदाहरण में एक्सेस किया है -

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; 
/

जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

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.