Package কি এবং কেন ব্যবহার করবেন?

PL/SQL এর Package ব্যবস্থাপনা - পিএল/এসকিউএল (PL/SQL) - Database Tutorials

511

PL/SQL এ Package হলো একটি ইউনিট যা এক বা একাধিক ফাংশন, প্রোসিডিউর, কনস্ট্যান্ট, ভেরিয়েবল এবং অন্য প্রোগ্রামিং উপাদান একত্রে গ্রুপ করে। এটি মডুলার প্রোগ্রামিং এর একটি গুরুত্বপূর্ণ অংশ, যা কোডের পুনঃব্যবহারযোগ্যতা, সুরক্ষা এবং রক্ষণাবেক্ষণ সহজতর করতে সাহায্য করে।


Package এর গঠন

PL/SQL এর package দুটি অংশে বিভক্ত থাকে:

  1. Package Specification (প্যাকেজ স্পেসিফিকেশন)
  2. Package Body (প্যাকেজ বডি)

১. Package Specification (প্যাকেজ স্পেসিফিকেশন):

এটি package এর "ইন্টারফেস" হিসেবে কাজ করে, যেখানে package এর পাবলিক প্রোগ্রাম উপাদান (যেমন ফাংশন, প্রোসিডিউর) ঘোষণা করা হয়। স্পেসিফিকেশন হল সেই অংশ যা অন্য কোড দ্বারা অ্যাক্সেসযোগ্য এবং এটি package এর বাইরে ব্যবহৃত হতে পারে।

সিনট্যাক্স:

CREATE OR REPLACE PACKAGE package_name AS
   -- Declarations of constants, variables, types
   FUNCTION function_name (parameters) RETURN datatype;
   PROCEDURE procedure_name (parameters);
END package_name;

উদাহরণ:

CREATE OR REPLACE PACKAGE employee_pkg AS
   -- Function declaration
   FUNCTION get_employee_salary (emp_id IN NUMBER) RETURN NUMBER;
   -- Procedure declaration
   PROCEDURE update_employee_salary (emp_id IN NUMBER, new_salary IN NUMBER);
END employee_pkg;

এখানে, employee_pkg নামের একটি প্যাকেজ তৈরি করা হয়েছে, যার মধ্যে একটি ফাংশন এবং একটি প্রোসিডিউর ডিক্লেয়ার করা হয়েছে।

২. Package Body (প্যাকেজ বডি):

এটি package এর "ইমপ্লিমেন্টেশন" অংশ, যেখানে ডিক্লেয়ার করা ফাংশন, প্রোসিডিউর ইত্যাদির কোড থাকে। এটি প্যাকেজ স্পেসিফিকেশনের ভিতরের উপাদানগুলোর বাস্তবায়ন সরবরাহ করে।

সিনট্যাক্স:

CREATE OR REPLACE PACKAGE BODY package_name AS
   -- Implementation of functions and procedures
   FUNCTION get_employee_salary (emp_id IN NUMBER) RETURN NUMBER IS
   BEGIN
      -- Function implementation
      RETURN (SELECT salary FROM employees WHERE employee_id = emp_id);
   END get_employee_salary;

   PROCEDURE update_employee_salary (emp_id IN NUMBER, new_salary IN NUMBER) IS
   BEGIN
      -- Procedure implementation
      UPDATE employees SET salary = new_salary WHERE employee_id = emp_id;
   END update_employee_salary;
END package_name;

এখানে, employee_pkg প্যাকেজের বডি অংশে get_employee_salary ফাংশন এবং update_employee_salary প্রোসিডিউরের বাস্তবায়ন দেওয়া হয়েছে।


Package ব্যবহারের সুবিধা

  1. মডুলারিটি এবং কোড সংগঠন:
    • Package ব্যবহারের মাধ্যমে আপনার কোডকে ছোট ছোট ইউনিটে ভাগ করা যায়, যার ফলে কোড আরও সুসংহত এবং রক্ষণাবেক্ষণযোগ্য হয়।
    • ফাংশন এবং প্রোসিডিউরগুলিকে একত্রে সংগঠিত করা যায়, যেগুলি একে অপরের সাথে সম্পর্কিত হতে পারে।
  2. কোড পুনঃব্যবহারযোগ্যতা:
    • একবার প্যাকেজ তৈরি করার পরে, আপনি বিভিন্ন PL/SQL ব্লক বা অ্যাপ্লিকেশন থেকে সেই প্যাকেজের ফাংশন এবং প্রোসিডিউর ব্যবহার করতে পারবেন। এটি কোড পুনঃব্যবহারযোগ্যতা বৃদ্ধি করে।
  3. অভ্যন্তরীণ সুরক্ষা (Encapsulation):
    • Package এর স্পেসিফিকেশনে শুধুমাত্র পাবলিক ফাংশন, প্রোসিডিউর এবং কনস্ট্যান্টগুলো থাকবে, এবং বডিতে গোপন (private) ফাংশন এবং ভেরিয়েবল থাকবে। এটি কোডের নিরাপত্তা নিশ্চিত করে কারণ বাইরের কোড সহজেই অভ্যন্তরীণ ডেটা বা প্রোগ্রাম উপাদান অ্যাক্সেস করতে পারে না।
  4. পারফরম্যান্স উন্নতি:
    • একবার প্যাকেজের অংশগুলি কম্পাইল হলে, এটি ডাটাবেসে ক্যাশে হয়ে যায়। ফলে একাধিকবার একই প্যাকেজের ফাংশন বা প্রোসিডিউর কল করলে কর্মক্ষমতা বৃদ্ধি পায়।
  5. দ্রুত অ্যাক্সেস:
    • একাধিক ফাংশন বা প্রোসিডিউর একটি প্যাকেজে রাখা হলে, আপনি সেই প্যাকেজটি একবার ডিক্লেয়ার করলেই সব ফাংশন এবং প্রোসিডিউর একসাথে ব্যবহার করতে পারবেন।
  6. ডিবাগিং এবং রক্ষণাবেক্ষণ:
    • প্যাকেজগুলি কোডের বিভাজন সুবিধা দেয়, যা ডিবাগিং এবং রক্ষণাবেক্ষণকে সহজ করে। প্যাকেজের প্রতিটি অংশ আলাদাভাবে পরীক্ষা এবং পরিবর্তন করা যায়।
  7. নাম স্পেস (Namespace):
    • প্যাকেজ নাম ব্যবহারের মাধ্যমে আপনি ফাংশন এবং প্রোসিডিউরের নামের মধ্যে কনফ্লিক্ট এড়াতে পারেন। অর্থাৎ, একাধিক প্যাকেজের মধ্যে একই নামের ফাংশন থাকতে পারে, কিন্তু কোডে একে অপরের সাথে সংঘর্ষ হবে না।

প্যাকেজের উদাহরণ

১. প্যাকেজ স্পেসিফিকেশন:

CREATE OR REPLACE PACKAGE employee_pkg AS
   -- Constant declaration
   c_bonus_rate CONSTANT NUMBER := 0.10;

   -- Function to get employee salary
   FUNCTION get_salary(emp_id IN NUMBER) RETURN NUMBER;

   -- Procedure to update employee salary
   PROCEDURE update_salary(emp_id IN NUMBER, new_salary IN NUMBER);
END employee_pkg;

২. প্যাকেজ বডি:

CREATE OR REPLACE PACKAGE BODY employee_pkg AS

   -- Function to get employee salary
   FUNCTION get_salary(emp_id IN NUMBER) RETURN NUMBER IS
      v_salary NUMBER;
   BEGIN
      SELECT salary INTO v_salary
      FROM employees
      WHERE employee_id = emp_id;

      RETURN v_salary;
   END get_salary;

   -- Procedure to update employee salary
   PROCEDURE update_salary(emp_id IN NUMBER, new_salary IN NUMBER) IS
   BEGIN
      UPDATE employees
      SET salary = new_salary
      WHERE employee_id = emp_id;
   END update_salary;

END employee_pkg;

এখানে,

  • employee_pkg প্যাকেজের মধ্যে একটি কনস্ট্যান্ট c_bonus_rate এবং দুটি উপাদান (ফাংশন এবং প্রোসিডিউর) রয়েছে, যা কর্মচারীর বেতন সম্পর্কিত কাজ করবে।

সারাংশ:

Package PL/SQL এ কোড সংগঠনের একটি শক্তিশালী উপায়। এটি কোডের পুনঃব্যবহারযোগ্যতা, সুরক্ষা এবং পারফরম্যান্স উন্নত করতে সাহায্য করে। প্যাকেজের স্পেসিফিকেশন এবং বডি দুটি প্রধান অংশের মাধ্যমে কার্যকরভাবে কোড পরিচালনা করা যায় এবং ডাটাবেস অ্যাপ্লিকেশনগুলোকে আরও মডুলার এবং সহজে রক্ষণাবেক্ষণযোগ্য করা যায়।

Content added By
Promotion

Are you sure to start over?

Loading...