DBMS_XMLGEN এবং DBMS_XMLQUERY ব্যবহার

PL/SQL এবং XML/JSON Integration - পিএল/এসকিউএল (PL/SQL) - Database Tutorials

306

Oracle PL/SQL তে XML ডেটার সাথে কাজ করার জন্য দুটি শক্তিশালী প্যাকেজ রয়েছে: DBMS_XMLGEN এবং DBMS_XMLQUERY। এগুলি XML ডেটা তৈরি এবং কুইরি করার জন্য ব্যবহৃত হয়। এই প্যাকেজগুলো XML ডেটা প্রক্রিয়াকরণকে আরও সহজ এবং কার্যকর করে তোলে। আসুন, এগুলোর ব্যবহার নিয়ে বিস্তারিত আলোচনা করি।


1. DBMS_XMLGEN প্যাকেজ

DBMS_XMLGEN প্যাকেজটি XML ফরম্যাটে ডেটা জেনারেট করতে ব্যবহৃত হয়। এটি SELECT কুয়েরি থেকে XML ফাইল তৈরি করে, যা বিভিন্ন অ্যাপ্লিকেশন বা সিস্টেমের সাথে ইন্টিগ্রেট করতে সাহায্য করে। এই প্যাকেজটি সাধারণত ডেটাবেস থেকে XML ডেটা এক্সট্র্যাক্ট করার জন্য ব্যবহৃত হয়।

মূল ফাংশন:

  • GETXML: একটি কুয়েরি (SELECT স্টেটমেন্ট) থেকে XML ডেটা তৈরি করে।
  • GETXMLTYPE: একটি XML ডেটাকে XMLTYPE আউটপুট হিসেবে রিটার্ন করে।

উদাহরণ:

DECLARE
   v_xml XMLTYPE;
BEGIN
   -- Retrieve data from a table and convert it to XML format
   v_xml := DBMS_XMLGEN.GETXML('SELECT emp_id, name FROM employees WHERE department_id = 10');
   
   -- Output the generated XML
   DBMS_OUTPUT.PUT_LINE(v_xml.getStringVal());
END;
/

এখানে:

  • DBMS_XMLGEN.GETXML ফাংশনটি SELECT কুয়েরি থেকে XML ডেটা তৈরি করে।
  • v_xml.getStringVal() ব্যবহার করে XML ডেটা আউটপুট হিসেবে দেখা যায়।

আউটপুট উদাহরণ:

<?xml version="1.0"?>
<ROWSET>
  <ROW>
    <EMP_ID>1001</EMP_ID>
    <NAME>John Doe</NAME>
  </ROW>
  <ROW>
    <EMP_ID>1002</EMP_ID>
    <NAME>Jane Smith</NAME>
  </ROW>
</ROWSET>

2. DBMS_XMLQUERY প্যাকেজ

DBMS_XMLQUERY প্যাকেজটি XML ডেটা কুয়েরি করার জন্য ব্যবহৃত হয়। এটি XML ডেটার ভিতরে কুয়েরি চালাতে, তথ্য বের করতে এবং XML ডেটার মধ্যে পরিবর্তন করতে সাহায্য করে। এই প্যাকেজটি মূলত XPath বা XQuery ব্যবহার করে XML ডেটাতে কুয়েরি চালাতে ব্যবহৃত হয়।

মূল ফাংশন:

  • EXTRACT: XPath ব্যবহার করে XML ডেটা থেকে তথ্য বের করে।
  • EXTRACTVALUE: XML ডেটা থেকে একক মান বের করে।
  • QUERY: XQuery ব্যবহার করে XML ডেটা থেকে বিভিন্ন তথ্য বের করতে পারে।

উদাহরণ:

DECLARE
   v_xml XMLTYPE;
   v_value VARCHAR2(100);
BEGIN
   -- Retrieve XML data from a table
   v_xml := DBMS_XMLGEN.GETXML('SELECT emp_id, name FROM employees WHERE department_id = 10');
   
   -- Query the XML data to extract employee names
   v_value := DBMS_XMLQUERY.EXTRACTVALUE(v_xml, '/ROWSET/ROW/NAME');
   
   -- Output the extracted value
   DBMS_OUTPUT.PUT_LINE('Employee Name: ' || v_value);
END;
/

এখানে:

  • DBMS_XMLGEN.GETXML ব্যবহার করে XML ডেটা তৈরি করা হয়েছে।
  • DBMS_XMLQUERY.EXTRACTVALUE ব্যবহার করে XML ডেটার মধ্যে থেকে NAME ট্যাগের মান বের করা হয়েছে।

আউটপুট উদাহরণ:

Employee Name: John Doe

3. DBMS_XMLGEN এবং DBMS_XMLQUERY এর মধ্যে পার্থক্য

ফিচারDBMS_XMLGENDBMS_XMLQUERY
কাজSQL কুয়েরি থেকে XML ডেটা তৈরি করে।XML ডেটা থেকে কুয়েরি চালিয়ে প্রয়োজনীয় তথ্য বের করে।
ফাংশনGETXML, GETXMLTYPEEXTRACT, EXTRACTVALUE, QUERY
ব্যবহারXML ডেটা প্রজন্মের জন্য ব্যবহৃত হয়।XML ডেটার ভিতরে কুয়েরি চালানোর জন্য ব্যবহৃত হয়।
উদাহরণDBMS_XMLGEN.GETXML ব্যবহার করে XML ডেটা তৈরি করা।DBMS_XMLQUERY.EXTRACTVALUE ব্যবহার করে XML থেকে ডেটা বের করা।

4. DBMS_XMLGEN এবং DBMS_XMLQUERY এর বাস্তব উদাহরণ

DBMS_XMLGEN উদাহরণ:

DECLARE
   v_xml XMLTYPE;
BEGIN
   -- Retrieve XML data using SELECT query
   v_xml := DBMS_XMLGEN.GETXML('SELECT emp_id, name FROM employees WHERE department_id = 10');
   
   -- Print the XML data
   DBMS_OUTPUT.PUT_LINE(v_xml.getStringVal());
END;
/

এখানে DBMS_XMLGEN.GETXML ব্যবহার করে employees টেবিল থেকে emp_id এবং name এর তথ্য XML ফরম্যাটে আনা হয়েছে।

DBMS_XMLQUERY উদাহরণ:

DECLARE
   v_xml XMLTYPE;
   v_value VARCHAR2(100);
BEGIN
   -- Retrieve XML data from a table
   v_xml := DBMS_XMLGEN.GETXML('SELECT emp_id, name FROM employees WHERE department_id = 10');
   
   -- Query the XML data to extract employee names using XPath
   v_value := DBMS_XMLQUERY.EXTRACTVALUE(v_xml, '/ROWSET/ROW/NAME');
   
   -- Output the extracted value
   DBMS_OUTPUT.PUT_LINE('Employee Name: ' || v_value);
END;
/

এখানে, DBMS_XMLQUERY.EXTRACTVALUE ব্যবহার করে XML ডেটার মধ্যে থেকে NAME ট্যাগের মান বের করা হয়েছে।


উপসংহার

DBMS_XMLGEN এবং DBMS_XMLQUERY হল শক্তিশালী প্যাকেজ যা XML ডেটা তৈরি এবং কুয়েরি করতে ব্যবহৃত হয়। এগুলি বিশেষভাবে তখন ব্যবহৃত হয় যখন ডেটাবেসের তথ্য XML ফরম্যাটে প্রক্রিয়াকরণ এবং এক্সচেঞ্জ করতে হয়। আপনি যদি PL/SQL তে XML ডেটা হ্যান্ডলিংয়ের জন্য কাজ করছেন, তবে এই প্যাকেজ দুটি অত্যন্ত কার্যকরী এবং উপকারী।

Content added By
Promotion

Are you sure to start over?

Loading...