PL/SQL Debugging Tools এবং Techniques

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

369

PL/SQL কোড ডিবাগিং হল একটি গুরুত্বপূর্ণ প্রক্রিয়া যা কোডে কোনো ভুল বা ত্রুটি সনাক্ত করতে এবং সেগুলি ঠিক করার জন্য ব্যবহৃত হয়। PL/SQL কোডে ডিবাগিং করতে আপনাকে বিভিন্ন টুলস এবং টেকনিক্স ব্যবহার করতে হবে যা ডেটাবেসের কার্যক্ষমতা উন্নত করতে সহায়তা করে। Oracle PL/SQL ডিবাগিং একটি শক্তিশালী প্রক্রিয়া যেখানে আপনি কোডের বিভিন্ন অংশ পর্যবেক্ষণ করতে এবং কন্ট্রোল করতে পারেন।

১. PL/SQL Debugger in Oracle SQL Developer

Oracle SQL Developer একটি শক্তিশালী ডিবাগিং টুল, যা Oracle Database এর সাথে ইন্টিগ্রেটেড হয়ে থাকে এবং PL/SQL ডিবাগিংয়ের জন্য ব্যবহৃত হয়। SQL Developer দ্বারা আপনি PL/SQL ব্লক এবং স্টোরড প্রোসিডিউর ডিবাগ করতে পারেন। এতে আপনি কোড স্টেপ বাই স্টেপ এক্সিকিউট করতে, ব্রেকপয়েন্ট সেট করতে, ভেরিয়েবল ভ্যালু দেখতে এবং ত্রুটি শনাক্ত করতে পারবেন।

SQL Developer Debugger - Features:

  • Step Through: কোডটি একে একে চলতে থাকে এবং আপনি প্রতিটি লাইনে কোড এক্সিকিউট করার প্রক্রিয়া দেখতে পাবেন।
  • Breakpoints: নির্দিষ্ট লাইনে ব্রেকপয়েন্ট সেট করতে পারবেন, যাতে কোড এক্সিকিউট করা থেমে থাকে এবং আপনি স্ট্যাটাস চেক করতে পারেন।
  • Watch Variables: আপনি ডিবাগিং চলাকালীন ভেরিয়েবলের মান পর্যবেক্ষণ করতে পারেন।
  • Call Stack: ফাংশন বা প্রোসিডিউরের কল স্ট্যাক দেখতে পারবেন।
  • Variable Inspection: কোড চলাকালীন ভেরিয়েবলের মান দেখতে পারবেন এবং পরবর্তী পদক্ষেপগুলি সিদ্ধান্ত নিতে পারবেন।

Steps to Debug in SQL Developer:

  1. Enable Debugging: SQL Developer এ Debugging অপশন সক্রিয় করুন।
  2. Set Breakpoints: কোডের যে লাইনে থামাতে চান সেখানে ব্রেকপয়েন্ট সেট করুন।
  3. Run Debugger: ডিবাগার চালু করুন এবং কোডটি স্টেপ বাই স্টেপ এক্সিকিউট করুন।
  4. Inspect Variables: কোড এক্সিকিউটের সময় ভেরিয়েবলের মান চেক করুন।
  5. Examine Call Stack: কোডে কোনো স্ট্যাক ট্রেস এর জন্য কল স্ট্যাক দেখতে পারেন।

২. DBMS_OUTPUT for Debugging

Oracle PL/SQL ডিবাগিংয়ের জন্য আরেকটি জনপ্রিয় টুল হল DBMS_OUTPUT। এই প্যাকেজটি ব্যবহার করে আপনি কোডে প্রিন্ট স্টেটমেন্ট ব্যবহার করে ভেরিয়েবলের মান এবং কোডের বিভিন্ন অংশে পরিবর্তন দেখতে পারেন।

How to Use DBMS_OUTPUT:

  • Enable DBMS_OUTPUT: ডিবাগিং শুরু করার আগে SET SERVEROUTPUT ON কমান্ড চালিয়ে DBMS_OUTPUT সক্রিয় করুন।
  • Use DBMS_OUTPUT.PUT_LINE: কোডের মধ্যে বিভিন্ন স্থানে PUT_LINE ফাংশন ব্যবহার করে ফলাফল প্রিন্ট করুন।

Example:

BEGIN
   DBMS_OUTPUT.PUT_LINE('Program Started');

   -- Declare variables
   DECLARE
      v_salary employees.salary%TYPE;
   BEGIN
      SELECT salary INTO v_salary FROM employees WHERE employee_id = 1001;
      DBMS_OUTPUT.PUT_LINE('Salary: ' || v_salary);
   END;
   DBMS_OUTPUT.PUT_LINE('Program Ended');
END;
/

উপরের উদাহরণে, DBMS_OUTPUT.PUT_LINE ব্যবহার করে কোডের বিভিন্ন অংশের মান প্রিন্ট করা হয়েছে। যখন কোডটি রান হবে, তখন আপনি SQL Developer বা SQL*Plus তে আউটপুট দেখতে পারবেন।

৩. EXCEPTION HANDLING for Debugging

PL/SQL তে Exception Handling একটি শক্তিশালী ডিবাগging টুল। যখন কোনো ত্রুটি ঘটে, তখন আপনি কাস্টম ত্রুটি বার্তা তৈরি করতে পারেন এবং সেই ত্রুটির বিস্তারিত লগ করতে পারেন। এটির মাধ্যমে আপনি ত্রুটি সনাক্ত করতে এবং সেগুলি সমাধান করতে পারেন।

Example:

BEGIN
   -- Code that may raise an error
   UPDATE employees SET salary = -1000 WHERE employee_id = 1001;

EXCEPTION
   WHEN OTHERS THEN
      -- Logging error message
      DBMS_OUTPUT.PUT_LINE('Error Occurred: ' || SQLERRM);
      -- RAISE_APPLICATION_ERROR can also be used for custom errors
      RAISE_APPLICATION_ERROR(-20001, 'Negative salary is not allowed!');
END;
/

এখানে, যদি কোনো ত্রুটি ঘটে (যেমন, নেতিবাচক স্যালারি ইনপুট), তখন সেই ত্রুটির বিস্তারিত DBMS_OUTPUT.PUT_LINE দ্বারা প্রিন্ট করা হবে এবং কাস্টম ত্রুটি বার্তা রাইজ হবে।

৪. Using Autonomous Transactions for Debugging

Autonomous Transactions একটি গুরুত্বপূর্ণ ডিবাগging টুল হিসেবে কাজ করে। এটি মূল ট্রানজেকশনের বাইরে একটি স্বতন্ত্র ট্রানজেকশন চালানোর সুবিধা প্রদান করে, যার মাধ্যমে আপনি কোনো প্রক্রিয়া পরীক্ষা করতে বা লগ করতে পারেন যাতে মূল ট্রানজেকশনটি প্রভাবিত না হয়।

Example:

-- Autonomous transaction for logging
CREATE OR REPLACE PROCEDURE log_error
IS
   PRAGMA AUTONOMOUS_TRANSACTION;
BEGIN
   INSERT INTO error_log (error_message, error_time) 
   VALUES ('An error occurred at ' || SYSDATE);
   COMMIT;
END;
/

BEGIN
   -- Call logging procedure in case of error
   log_error;
EXCEPTION
   WHEN OTHERS THEN
      -- Call log_error in case of exception
      log_error;
      -- Handle the error
      DBMS_OUTPUT.PUT_LINE('Error logged');
END;
/

এখানে, PRAGMA AUTONOMOUS_TRANSACTION ব্যবহার করে একটি পৃথক ট্রানজেকশন তৈরি করা হয়েছে যা মূল প্রক্রিয়ার চলাকালীন ত্রুটির লগ ইনসার্ট করবে।

৫. Using PL/SQL Profiler

PL/SQL Profiler ব্যবহার করে আপনি কোডের পারফরম্যান্স বিশ্লেষণ করতে পারেন, যেমন কোডটি কতটা সময় নিচ্ছে এক্সিকিউট হতে, কোন লাইনটি স্লো পারফর্ম করছে, এবং কোথায় পঠনযোগ্যতা এবং দক্ষতা বৃদ্ধি করা যেতে পারে।

Steps to Use Profiler:

  1. Enable Profiler:

    ALTER SESSION SET plsql_profiler=TRUE;
    
  2. Run the Code: আপনার PL/SQL কোড রান করুন।
  3. Analyze Results: DBMS_PROFILER প্যাকেজ ব্যবহার করে কোডের পারফরম্যান্স পর্যালোচনা করুন।

Example:

BEGIN
   DBMS_PROFILER.START_PROFILER('test_profile');
   -- Your PL/SQL code here
   DBMS_PROFILER.STOP_PROFILER;
END;
/

এটি কোডের পারফরম্যান্স পর্যালোচনা করে এবং স্লো পারফর্মিং লাইনগুলো চিহ্নিত করতে সহায়তা করবে।

৬. Unit Testing with PL/SQL

PL/SQL ইউনিট টেস্টিং একটি পদ্ধতি যেখানে আপনি আপনার কোডের প্রতিটি অংশ পরীক্ষণ করেন। এতে আপনার কোডের কার্যক্ষমতা নিশ্চিত হয় এবং ত্রুটি দূর করতে সহজ হয়।

  • UTPLSQL: এটি PL/SQL এর জন্য একটি টেস্টিং ফ্রেমওয়ার্ক, যা ইউনিট টেস্টিং করার জন্য ব্যবহৃত হয়। এর মাধ্যমে আপনি সিস্টেমের ফাংশনালিটি এবং কোডের নির্ভরযোগ্যতা পরীক্ষা করতে পারেন।

Example:

CREATE OR REPLACE PACKAGE my_test_package IS
   PROCEDURE test_salary_update;
END;
/
CREATE OR REPLACE PACKAGE BODY my_test_package IS
   PROCEDURE test_salary_update IS
   BEGIN
      -- Test logic here
      ASSERT(salary_update(1001, 5000) = 'Success');
   END;
END;
/

এই কোডটি ইউনিট টেস্টিং ফ্রেমওয়ার্ক তৈরি করতে সাহায্য করবে যা আপনাকে কোডের প্রত্যেকটি অংশ পর্যালোচনা করতে দেবে।

উপসংহার

PL/SQL ডিবাগিং একটি অত্যন্ত গুরুত্বপূর্ণ কার্যক্রম যা আপনাকে কোডের সমস্যা চিহ্নিত করতে এবং কার্যকরভাবে সেগুলি সমাধান করতে সহায়তা করে। SQL Developer, DBMS_OUTPUT, Exception Handling, Autonomous Transactions এবং Profiler ইত্যাদি টুলস ও টেকনিক্সের মাধ্যমে আপনি সহজে PL/SQL কোড ডিবাগ করতে পারবেন এবং এর কার্যক্ষমতা উন্নত করতে পারবেন।

Content added By
Promotion

Are you sure to start over?

Loading...