DBMS_OUTPUT প্যাকেজ ব্যবহার

PL/SQL Debugging এবং Testing - পিএল/এসকিউএল (PL/SQL) - Database Tutorials

310

Oracle PL/SQL এ DBMS_OUTPUT প্যাকেজ একটি প্রি-ডিফাইনড প্যাকেজ যা ডিবাগিং, লোগিং এবং আউটপুট প্রদর্শনের জন্য ব্যবহৃত হয়। এটি প্রোগ্রাম রান টাইমে আপনার PL/SQL ব্লক বা প্রোসিডিউর থেকে বার্তা (message) প্রিন্ট করতে সাহায্য করে। এর মাধ্যমে আপনি কোডে কী হচ্ছে তা দেখতে পারেন, যেমন ভেরিয়েবলের মান, প্রক্রিয়ার অবস্থা বা ত্রুটির বার্তা।

এটি বিশেষভাবে ডিবাগিং বা ট্রেসিং এর সময় খুবই উপকারী, কারণ এটি পছন্দের আউটপুট (উদাহরণস্বরূপ ভেরিয়েবলের মান বা মেসেজ) Oracle SQL*Plus বা Oracle SQL Developer তে দেখতে সাহায্য করে।


DBMS_OUTPUT প্যাকেজের মেথডসমূহ

  1. PUT_LINE: এটি সবচেয়ে সাধারণ এবং সবচেয়ে বেশি ব্যবহৃত ফাংশন। এই ফাংশনটি এক বা একাধিক লাইন আউটপুট করতে সাহায্য করে। এটি একটি স্ট্রিং আর্গুমেন্ট গ্রহণ করে এবং সেই স্ট্রিংটিকে আউটপুট হিসাবে প্রদর্শন করে।
  2. ENABLE: এই ফাংশনটি DBMS_OUTPUT এর আউটপুট দেখানোর জন্য সক্রিয় (enable) করে। এটি ব্যবহার না করলে আউটপুট দেখানো যাবে না।
  3. DISABLE: এটি DBMS_OUTPUT এর আউটপুট বন্ধ (disable) করে। এর মাধ্যমে আপনি আউটপুট স্ট্রীম বন্ধ করতে পারেন।
  4. GET_LINES: এই ফাংশনটি DBMS_OUTPUT এর আউটপুট স্ট্রীমের জন্য লাইনের সংখ্যা ফেরত দেয়। এটি কাস্টম আউটপুট সংগ্রহ করতে ব্যবহৃত হতে পারে।

DBMS_OUTPUT এর সাধারণ ব্যবহারের উদাহরণ

1. DBMS_OUTPUT.PUT_LINE ব্যবহার

এটি একটি সাধারণ ব্যবহার যেখানে কোডের মধ্যে একটি মেসেজ প্রিন্ট করা হয়:

BEGIN
    DBMS_OUTPUT.PUT_LINE('Hello, this is a test message.');
END;
/

এই কোডটি Oracle SQL*Plus বা Oracle SQL Developer এর আউটপুট উইন্ডোতে Hello, this is a test message. এই বার্তাটি প্রদর্শন করবে।

2. DBMS_OUTPUT.PUT_LINE এবং ভেরিয়েবলের মান প্রিন্ট করা

আপনি একটি ভেরিয়েবলের মানও DBMS_OUTPUT এর মাধ্যমে আউটপুট করতে পারেন:

DECLARE
    v_salary NUMBER := 5000;
BEGIN
    DBMS_OUTPUT.PUT_LINE('The salary is: ' || v_salary);
END;
/

এখানে, আউটপুট হবে: The salary is: 5000

3. DBMS_OUTPUT.PUT_LINE ব্যবহার Multiple Lines এ আউটপুট

আপনি একাধিক বার্তা প্রিন্ট করতে পারেন, যেমন:

BEGIN
    DBMS_OUTPUT.PUT_LINE('First Line of Output');
    DBMS_OUTPUT.PUT_LINE('Second Line of Output');
    DBMS_OUTPUT.PUT_LINE('Third Line of Output');
END;
/

এটি আউটপুটে তিনটি আলাদা লাইন হিসেবে প্রদর্শিত হবে।


DBMS_OUTPUT.ENABLE এবং DBMS_OUTPUT.DISABLE ব্যবহার

DBMS_OUTPUT.PUT_LINE এর আউটপুট দেখানোর জন্য আপনাকে প্রথমে DBMS_OUTPUT.ENABLE ফাংশনটি ব্যবহার করে আউটপুট স্ট্রীম সক্রিয় করতে হবে। যদি এটি না করেন, তাহলে আউটপুটটি দেখা যাবে না।

BEGIN
    DBMS_OUTPUT.ENABLE(NULL);  -- Enable DBMS_OUTPUT
    DBMS_OUTPUT.PUT_LINE('This is an enabled output message.');
    DBMS_OUTPUT.DISABLE;       -- Disable DBMS_OUTPUT
END;
/

এটি আউটপুট করবে:

This is an enabled output message.

এছাড়া, আপনি DBMS_OUTPUT.DISABLE ব্যবহার করে আউটপুট বন্ধ করতে পারেন।


DBMS_OUTPUT.GET_LINES ব্যবহার

DBMS_OUTPUT.GET_LINES একটি কাস্টম আউটপুট সংগ্রহের জন্য ব্যবহৃত হয়। এই ফাংশনটি আউটপুটের লাইনের সংখ্যা ফেরত দেয়। এর মাধ্যমে আপনি আউটপুটের প্রথম কয়েকটি লাইনের মান সংগ্রহ করতে পারেন।

DECLARE
    v_lines DBMS_OUTPUT.chararr;
    v_count NUMBER;
BEGIN
    -- Enable DBMS_OUTPUT
    DBMS_OUTPUT.ENABLE;

    -- Print some lines
    DBMS_OUTPUT.PUT_LINE('Line 1: This is a test.');
    DBMS_OUTPUT.PUT_LINE('Line 2: This is another test.');

    -- Get the lines
    DBMS_OUTPUT.GET_LINES(v_lines, v_count);

    -- Display fetched lines
    FOR i IN 1..v_count LOOP
        DBMS_OUTPUT.PUT_LINE('Fetched Line ' || i || ': ' || v_lines(i));
    END LOOP;
END;
/

এটি DBMS_OUTPUT এর প্রথম দুইটি লাইনের মান কাস্টমভাবে সংগ্রহ করবে এবং প্রিন্ট করবে।


DBMS_OUTPUT এর সুবিধা ও সীমাবদ্ধতা

সুবিধা:

  1. ডিবাগিং সহায়ক: কোডে কোথায় কী হচ্ছে তা বুঝতে সাহায্য করে, বিশেষ করে যখন কিছু সমস্যা সমাধান করতে হয়।
  2. লগিং ফিচার: এটি একটি সিম্পল আউটপুট পদ্ধতি হিসেবে কাজ করে, যা অন্য কোনো লগিং সিস্টেম ছাড়াই প্রোগ্রামের ভিতরে আউটপুট দেয়।

সীমাবদ্ধতা:

  1. পারফরম্যান্স: অধিক পরিমাণে ডিবাগ মেসেজ প্রিন্ট করলে পারফরম্যান্সে কিছুটা প্রভাব পড়তে পারে।
  2. SQL*Plus নির্ভরতা: DBMS_OUTPUT সাধারণত SQL*Plus বা SQL Developer তে দেখা যায়, এবং কিছু গ্রাফিক্যাল ইউআইতে এটি সীমাবদ্ধ থাকতে পারে।

সারাংশ

DBMS_OUTPUT একটি শক্তিশালী টুল যা PL/SQL প্রোগ্রামে ডিবাগিং এবং আউটপুট প্রিন্ট করার জন্য ব্যবহৃত হয়। এটি সহজে ব্যবহৃত হয় PL/SQL ব্লকের মধ্যে বিভিন্ন তথ্য এবং বার্তা প্রিন্ট করতে, এবং ডিবাগিং বা লগিং প্রক্রিয়ায় সহায়তা করে। তবে, এটি প্রধানত SQL*Plus বা SQL Developer তে কার্যকরী।

Content added By
Promotion

Are you sure to start over?

Loading...