Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

PLPDF_TOOLKIT PL/SQL पैकेज का उपयोग करके Oracle में एकाधिक PDF फ़ाइलों को एक PDF में मर्ज/एकीकृत करें

इस ट्यूटोरियल में, मैं PLPDF_TOOLKIT PL/SQL पैकेज का उपयोग करके Oracle में एक PDF फ़ाइल में एकाधिक PDF फ़ाइलों को मर्ज/एकीकृत करने के लिए एक उदाहरण दे रहा हूँ।

मान लें कि आपके पास BLOB फ़ील्ड वाले कर्मचारियों के लिए एक तालिका है और प्रत्येक कर्मचारी के लिए इस तालिका में PDF प्रारूप में कई दस्तावेज़ हैं और आप एक कर्मचारी के लिए इन सभी दस्तावेज़ों को एक दस्तावेज़ में मर्ज करना चाहते हैं और इसे किसी अन्य तालिका के BLOB फ़ील्ड में सहेजना चाहते हैं।

पीडीएफ फाइलों को बीएलओबी कॉलम में कैसे सेव करें, इसके लिए आप मेरी पिछली पोस्ट देख सकते हैं, नीचे दी गई सूची है:

  • पीएल/एसक्यूएल में फाइल से बीएलओबी कैसे प्राप्त करें?
  • पीएल/एसक्यूएल में बीएलओबी को फाइल के रूप में कैसे सेव करें?
  • Oracle में BLOB से फ़ाइल कैसे प्राप्त करें?

उपर्युक्त पोस्ट से, आप सीखेंगे कि सिंगल पीडीएफ को कैसे सेव करें और सिंगल पीडीएफ वाले बीएलओबी डेटा को कैसे निकालें। यहां आप सीखेंगे कि एक से अधिक पीडीएफ फाइलों को एक पीडीएफ फाइल में कैसे संयोजित करें और एक बीएलओबी में स्टोर करें।

PLPDF_TOOLKIT.MERGE फ़ंक्शन का उपयोग करके एक से अधिक PDF को एक PDF फ़ाइल में मर्ज/एकीकृत करें

प्रत्येक कर्मचारी के लिए बीएलओबी में संग्रहीत कई पीडीएफ फाइलें (एकाधिक रिकॉर्ड में) रखने के लिए कर्मचारी तालिका की सरल संरचना निम्नलिखित है। इस तालिका से, हम फ़ाइलों को मर्ज करने के लिए प्राप्त करेंगे। परीक्षण के लिए, यह तालिका बनाएं और कर्मचारी संख्या 76465 ​​के लिए कुछ एकाधिक रिकॉर्ड (पीडीएफ फाइलें) डालें:

1. स्रोत तालिका बनाएं

Create Table Emp_Docs (
empno number,
blob_data blob
);

2. मर्ज किए गए PDF को संग्रहीत करने के लिए एक तालिका बनाएं

अब एक कर्मचारी के लिए मर्ज की गई पीडीएफ फाइलों को स्टोर करने के लिए एक टेबल बनाएं:

Create Table Emp_Pdfs (
empno number,
merged_pdf blob
);

3. PDF को मर्ज करने के लिए PL/SQL प्रोग्राम बनाएं

फिर कर्मचारी 76465 ​​के लिए पीडीएफ फाइलों को प्राप्त करने के लिए निम्नलिखित पीएल/एसक्यूएल कोड चलाएं, एक पीडीएफ फाइल में विलय करें और इसे Emp_Pdfs टेबल पर स्टोर करें। इस कार्य को करने के लिए, मैं PLPDF_TOOLKIT.MERGE फ़ंक्शन का उपयोग कर रहा हूँ।

Declare

  l_Blob1 BLOB; 
  l_Blob2 BLOB; 
  l_Blob3 BLOB; 
 
  CURSOR Cur_empDocs IS 
    SELECT blob_data, 
           Rownum Row_n 
      FROM emp_docs 
     WHERE empno = 76465;

  n_Count   INTEGER := 0; 
BEGIN
 
  FOR c IN Cur_empDocs LOOP 
    IF c.row_n = 1 THEN 
      Dbms_Lob.Createtemporary(Lob_Loc => l_Blob1, 
                               Cache   => TRUE, 
                               Dur     => Dbms_Lob.Call); 
      l_Blob1 := c.blob_data; 
     
    ELSE 
      Dbms_Lob.Createtemporary(Lob_Loc => l_Blob2, 
                               Cache   => TRUE, 
                               Dur     => Dbms_Lob.Call); 
      l_Blob2 := c.blob_data; 
     
      Dbms_Lob.Createtemporary(Lob_Loc => l_Blob3, 
                               Cache   => TRUE, 
                               Dur     => Dbms_Lob.Call); 
     
      l_Blob3 := Plpdf_Toolkit.Merge(l_Blob1, 
                                     l_Blob2); 
     
      l_Blob1 := l_Blob3; 
     
    END IF; 
    n_Count := n_Count + 1; 
  END LOOP; 
 
  IF n_Count > 0 THEN 
   
    insert into emp_pdfs (empno, merged_pdf) values (76465, l_blob1);
   
    COMMIT; 
 
  END IF; 
EXCEPTION 
  WHEN OTHERS THEN 
    raise;
END;

उदाहरण के लिए, यदि कर्मचारी 76465 ​​के लिए 3 रिकॉर्ड में 3 PDF फ़ाइलें संग्रहीत हैं, तो इसे एक PDF में संयोजित किया जाएगा। यहां तक ​​कि अगर किसी कर्मचारी के लिए केवल एक पीडीएफ दस्तावेज़ है तो वह केवल एक को ही संग्रहीत करेगा।

परिणाम देखने के लिए आप तालिका Emp_Pdfs को क्वेरी कर सकते हैं।

यह भी देखें:

  • ओरेकल एपेक्स पेज में एक क्षेत्र में बीएलओबी सामग्री (पीडीएफ, छवियां) प्रदर्शित करें
  • पीएल/एसक्यूएल का उपयोग करके पीडीएफ रिपोर्ट कैसे बनाएं

  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Oracle 11g डेटाबेस को दूरस्थ रूप से कैसे कनेक्ट करें

  2. पीएल/एसक्यूएल का उपयोग करके ओरेकल में लॉग फाइल कैसे बनाएं?

  3. पता लगाएं कि आपका सत्र Oracle में किस मुद्रा प्रतीक का उपयोग करता है

  4. Oracle .Net ManagedDataAccess त्रुटि:असेंबली से 'OracleInternal.Common.ConfigBaseClass' प्रकार लोड नहीं कर सका

  5. WHERE IN क्लॉज में उपयोग करने के लिए Oracle प्रक्रिया में मानों की एक सरणी भेजना