PL/SQL এর Package ব্যবস্থাপনা

পিএল/এসকিউএল (PL/SQL) - Database Tutorials

371

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

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

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

  • এখানে public elements ঘোষণা করা হয়, যেগুলি প্যাকেজের বাইরে থেকে অ্যাক্সেস করা যাবে।
  • private elements (যেগুলি শুধুমাত্র প্যাকেজের ভিতরে ব্যবহার করা হয়) Package Body-তে ঘোষণা করা হয়।

Package Specification এর সিমেন্ট্যাক্স:

CREATE OR REPLACE PACKAGE package_name AS
   -- Declaration of public variables, constants, cursors, functions, and procedures
   v_variable_name data_type; 
   FUNCTION function_name(parameter_list) RETURN return_type;
   PROCEDURE procedure_name(parameter_list);
   -- More declarations
END package_name;

উদাহরণ:

CREATE OR REPLACE PACKAGE employee_package AS
   -- Public variables
   v_employee_count NUMBER;

   -- Public function to get employee count
   FUNCTION get_employee_count RETURN NUMBER;

   -- Public procedure to hire employee
   PROCEDURE hire_employee (emp_name VARCHAR2, emp_salary NUMBER);

END employee_package;

এখানে:

  • v_employee_count: একটি পাবলিক ভেরিয়েবল যা পুরো প্যাকেজের ভিতরে অ্যাক্সেস করা যাবে।
  • get_employee_count: একটি পাবলিক ফাংশন যা মোট কর্মচারীর সংখ্যা রিটার্ন করবে।
  • hire_employee: একটি পাবলিক প্রোসিডিউর যা নতুন কর্মচারী নিয়োগ করবে।

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

Package Body হল প্যাকেজের কার্যকর অংশ, যেখানে পাবলিক ডিক্লেয়ার করা ফাংশন এবং প্রোসিডিউরের বাস্তবায়ন করা হয়। এর মধ্যে আপনি পাবলিক ফাংশন বা প্রোসিডিউরের পুরো লজিক লেখেন। এছাড়াও, এখানে আপনি প্যাকেজের private উপাদানগুলি (যেমন private ফাংশন, প্রোসিডিউর, এবং ভেরিয়েবল) ঘোষণা এবং ব্যবহার করতে পারেন।

Package Body এর সিমেন্ট্যাক্স:

CREATE OR REPLACE PACKAGE BODY package_name AS
   -- Private variables, cursors, functions, and procedures
   v_private_variable NUMBER;

   -- Implementation of public function
   FUNCTION get_employee_count RETURN NUMBER IS
   BEGIN
      SELECT COUNT(*) INTO v_employee_count FROM employees;
      RETURN v_employee_count;
   END get_employee_count;

   -- Implementation of public procedure
   PROCEDURE hire_employee (emp_name VARCHAR2, emp_salary NUMBER) IS
   BEGIN
      INSERT INTO employees (employee_name, salary) VALUES (emp_name, emp_salary);
   END hire_employee;

END package_name;

এখানে:

  • get_employee_count: পাবলিক ফাংশনটির কার্যকর অংশ, যা employees টেবিল থেকে মোট কর্মচারী সংখ্যা আনে।
  • hire_employee: একটি প্রোসিডিউর যা নতুন কর্মচারীকে employees টেবিলে যুক্ত করে।

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

PL/SQL প্যাকেজ ব্যবহারের অনেক সুবিধা রয়েছে, যার মধ্যে রয়েছে:

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

৪. Package Management (প্যাকেজ ব্যবস্থাপনা)

PL/SQL প্যাকেজ ব্যবস্থাপনা যেমন প্যাকেজ তৈরি, পরিবর্তন, এবং ডিবাগ করা যেতে পারে।

১. প্যাকেজ তৈরি করা (Creating a Package):

প্যাকেজ তৈরি করার জন্য, প্রথমে Specification এবং তারপর Body তৈরি করতে হয়। উদাহরণস্বরূপ:

Specification:

CREATE OR REPLACE PACKAGE my_package AS
   FUNCTION add_numbers (num1 NUMBER, num2 NUMBER) RETURN NUMBER;
END my_package;

Body:

CREATE OR REPLACE PACKAGE BODY my_package AS
   FUNCTION add_numbers (num1 NUMBER, num2 NUMBER) RETURN NUMBER IS
   BEGIN
      RETURN num1 + num2;
   END add_numbers;
END my_package;

২. প্যাকেজ পরিবর্তন করা (Modifying a Package):

প্যাকেজের স্পেসিফিকেশন বা বডি পরিবর্তন করার জন্য, CREATE OR REPLACE কমান্ড ব্যবহার করতে হয়।

উদাহরণ:

CREATE OR REPLACE PACKAGE BODY my_package AS
   FUNCTION add_numbers (num1 NUMBER, num2 NUMBER) RETURN NUMBER IS
   BEGIN
      RETURN num1 + num2 + 10;  -- Updated logic
   END add_numbers;
END my_package;

৩. প্যাকেজ ড্রপ করা (Dropping a Package):

প্যাকেজ এবং তার বডি মুছে ফেলতে DROP PACKAGE কমান্ড ব্যবহার করা হয়।

উদাহরণ:

DROP PACKAGE my_package;

৪. প্যাকেজের উপাদান পরীক্ষা করা (Checking Package Elements):

যদি আপনি একটি প্যাকেজের উপাদান বা ডিফিনেশন দেখতে চান, তাহলে ALL_OBJECTS অথবা USER_OBJECTS ভিউ ব্যবহার করতে পারেন।

উদাহরণ:

SELECT object_name, object_type
FROM user_objects
WHERE object_type = 'PACKAGE';

সারাংশ:

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

Content added By

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

PL/SQL-এ Package হল একটি গ্রুপিং বা মোডিউল যা একাধিক Procedure, Function, এবং Variables একত্রিত করে। এটি কোডের পুনঃব্যবহারযোগ্যতা, পরিচালনযোগ্যতা এবং সিকিউরিটি উন্নত করার জন্য ব্যবহৃত হয়। প্যাকেজ দুটি প্রধান অংশে বিভক্ত: Specification এবং Body

1. Package Specification

Package Specification হল প্যাকেজের একটি পাবলিক অংশ, যেখানে প্যাকেজের সমস্ত পাবলিক উপাদান (যেমন Functions, Procedures, Constants, Variables, Types) ঘোষণা করা হয়। এটি হল সেই অংশ, যা অন্য PL/SQL ব্লক এবং অ্যাপ্লিকেশন কোড দ্বারা অ্যাক্সেসযোগ্য থাকে।

Package Specification-এ আপনি কেবলমাত্র ঘোষণা করতে পারবেন, বাস্তবায়ন বা লজিক এখানে থাকবে না।

Syntax:

CREATE OR REPLACE PACKAGE package_name AS
   -- Declarations of types, variables, constants, procedures, and functions
   FUNCTION function_name (param1 datatype) RETURN return_type;
   PROCEDURE procedure_name(param1 datatype);
   -- Other declarations
END package_name;

উদাহরণ:

CREATE OR REPLACE PACKAGE employee_package AS
   -- Variable Declaration
   v_company_name VARCHAR2(100);
   
   -- Function Declaration
   FUNCTION get_employee_salary (emp_id NUMBER) RETURN NUMBER;
   
   -- Procedure Declaration
   PROCEDURE update_employee_salary (emp_id NUMBER, new_salary NUMBER);
   
   -- Constant Declaration
   c_minimum_salary CONSTANT NUMBER := 2000;
END employee_package;

এখানে, employee_package প্যাকেজের মধ্যে একটি ভেরিয়েবল (v_company_name), একটি ফাংশন (get_employee_salary), একটি প্রোসিডিউর (update_employee_salary), এবং একটি কনস্ট্যান্ট (c_minimum_salary) ডিক্লেয়ার করা হয়েছে।


2. Package Body

Package Body হল প্যাকেজের গোপন অংশ যেখানে প্যাকেজের ফাংশন, প্রোসিডিউর, এবং অন্যান্য ঘোষিত উপাদানগুলোর বাস্তবায়ন (implementation) করা হয়। Package Body ছাড়া Specification তৈরি করা সম্ভব, কিন্তু তা কার্যকরী হবে না যতক্ষণ না তার বাস্তবায়ন করা না হয়।

Package Body-এ Specification-এ ঘোষণা করা সব ফাংশন, প্রোসিডিউর ইত্যাদির বাস্তবায়ন থাকতে হবে।

Syntax:

CREATE OR REPLACE PACKAGE BODY package_name AS
   -- Actual implementation of declared functions, procedures, etc.
   FUNCTION function_name (param1 datatype) RETURN return_type IS
   BEGIN
      -- Function logic
   END function_name;
   
   PROCEDURE procedure_name(param1 datatype) IS
   BEGIN
      -- Procedure logic
   END procedure_name;
   
   -- Other implementations
END package_name;

উদাহরণ:

CREATE OR REPLACE PACKAGE BODY employee_package AS
   -- Function Implementation
   FUNCTION get_employee_salary (emp_id NUMBER) RETURN NUMBER IS
      v_salary NUMBER(8, 2);
   BEGIN
      SELECT salary INTO v_salary
      FROM employees
      WHERE employee_id = emp_id;
      RETURN v_salary;
   END get_employee_salary;
   
   -- Procedure Implementation
   PROCEDURE update_employee_salary (emp_id NUMBER, new_salary NUMBER) IS
   BEGIN
      UPDATE employees
      SET salary = new_salary
      WHERE employee_id = emp_id;
      COMMIT;
   END update_employee_salary;
   
END employee_package;

এখানে, get_employee_salary ফাংশনটি একটি কর্মচারীর বেতন রিট্রিভ করার জন্য এবং update_employee_salary প্রোসিডিউরটি কর্মচারীর বেতন আপডেট করার জন্য বাস্তবায়ন করা হয়েছে।


Package Specification এবং Body এর পার্থক্য

  • Specification:
    • এটি প্যাকেজের পাবলিক অংশ, যেখানে আপনি ডিক্লেয়ারেশন করেন, কিন্তু বাস্তবায়ন করেন না।
    • Specification অংশ থেকে অ্যাপ্লিকেশন বা অন্য PL/SQL কোড প্যাকেজের উপাদানগুলো (যেমন ফাংশন বা প্রোসিডিউর) অ্যাক্সেস করতে পারে।
  • Body:
    • এটি প্যাকেজের প্রাইভেট অংশ, যেখানে আপনি Specification-এ ডিক্লেয়ার করা উপাদানগুলোর বাস্তবায়ন করেন।
    • Body অংশের মধ্যে বাস্তবায়ন থাকে, এবং এখানে আপনি ফাংশন বা প্রোসিডিউরের লজিক লিখেন।

Package-এর ব্যবহার এবং সুবিধা

  1. Modularity: প্যাকেজের মাধ্যমে কোডকে মডুলার করা যায়, যেখানে একাধিক ফাংশন ও প্রোসিডিউর একসাথে কাজ করে।
  2. Encapsulation: প্যাকেজে কোডের বাস্তবায়ন এবং ডিক্লেয়ারেশন আলাদা করা যায়, যা কোডের রক্ষণাবেক্ষণ সহজ করে।
  3. Code Reusability: একবার প্যাকেজ তৈরি করলে সেটি একাধিক PL/SQL ব্লকে ব্যবহার করা যেতে পারে।
  4. Security: প্যাকেজের মাধ্যমে সিকিউরিটি নিশ্চিত করা যায়, কারণ আপনি পাবলিক এবং প্রাইভেট অংশ পৃথক করতে পারেন।
  5. Performance: প্যাকেজের উপাদানগুলো একবার লোড হলে পরবর্তীতে দ্রুত এক্সিকিউট হয়, কারণ পুরো প্যাকেজটি মেমরিতে থাকে।

Package এর এক্সিকিউশন উদাহরণ:

এখন, চলুন দেখি কীভাবে আমরা employee_package প্যাকেজটি ব্যবহার করতে পারি।

ফাংশন কল করা:

DECLARE
   v_salary NUMBER;
BEGIN
   v_salary := employee_package.get_employee_salary(101); -- Employee ID 101
   DBMS_OUTPUT.PUT_LINE('Employee Salary: ' || v_salary);
END;

প্রোসিডিউর কল করা:

BEGIN
   employee_package.update_employee_salary(101, 5500); -- Update salary for employee 101
   DBMS_OUTPUT.PUT_LINE('Employee salary updated successfully.');
END;

Conclusion:

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

Content added By

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

  1. Package Specification (Specification): এটি পাবলিক অংশ, যেখানে সমস্ত প্রাসঙ্গিক ফাংশন, প্রোসিডিউর, কনস্ট্যান্ট, টাইপ এবং ভেরিয়েবল ঘোষিত হয় এবং অ্যাক্সেস করা যায়।
  2. Package Body (Body): এটি প্রাইভেট অংশ, যেখানে ফাংশন এবং প্রোসিডিউরের বাস্তবায়ন (implementation) থাকে।

১. Functions

Functions হল এমন প্রোগ্রাম কোড, যা নির্দিষ্ট কিছু ইনপুট নিয়ে কাজ করে এবং একটি মান রিটার্ন করে। ফাংশন সাধারণত কোনও ক্যালকুলেশন বা অপারেশন করতে ব্যবহৃত হয়।

  • Package Specification-এ ফাংশনটির ঘোষণা করা হয়।
  • Package Body-এ ফাংশনটির বাস্তবায়ন হয়।

Syntax:

-- Package Specification (Declaration)
FUNCTION function_name (param1 datatype, param2 datatype) RETURN return_type;

-- Package Body (Implementation)
FUNCTION function_name (param1 datatype, param2 datatype) RETURN return_type IS
BEGIN
   -- Function Logic
   RETURN result;
END function_name;

উদাহরণ:

-- Package Specification
CREATE OR REPLACE PACKAGE employee_pkg AS
   FUNCTION calculate_bonus(salary NUMBER) RETURN NUMBER;
END employee_pkg;

-- Package Body
CREATE OR REPLACE PACKAGE BODY employee_pkg AS
   FUNCTION calculate_bonus(salary NUMBER) RETURN NUMBER IS
   BEGIN
      RETURN salary * 0.1; -- 10% bonus
   END calculate_bonus;
END employee_pkg;

২. Procedures

Procedures হল কোড ব্লক, যা একটি বা একাধিক স্টেটমেন্ট নিয়ে গঠিত এবং এটি কোনও মান রিটার্ন করে না। প্রোসিডিউর সাধারণত কোনো কাজ সম্পাদন বা প্রক্রিয়া চালাতে ব্যবহৃত হয়।

  • Package Specification-এ প্রোসিডিউরের ঘোষণা করা হয়।
  • Package Body-এ প্রোসিডিউরের বাস্তবায়ন হয়।

Syntax:

-- Package Specification (Declaration)
PROCEDURE procedure_name (param1 datatype, param2 datatype);

-- Package Body (Implementation)
PROCEDURE procedure_name (param1 datatype, param2 datatype) IS
BEGIN
   -- Procedure Logic
END procedure_name;

উদাহরণ:

-- Package Specification
CREATE OR REPLACE PACKAGE employee_pkg AS
   PROCEDURE give_raise(employee_id NUMBER, raise_amount NUMBER);
END employee_pkg;

-- Package Body
CREATE OR REPLACE PACKAGE BODY employee_pkg AS
   PROCEDURE give_raise(employee_id NUMBER, raise_amount NUMBER) IS
   BEGIN
      UPDATE employees
      SET salary = salary + raise_amount
      WHERE emp_id = employee_id;
      COMMIT;
   END give_raise;
END employee_pkg;

৩. Variables

Variables হল এমন ডেটা ধারণকারী উপাদান যা প্রোগ্রামের চলাকালীন সময়ে মান ধারণ করতে ব্যবহৃত হয়। প্যাকেজে ভেরিয়েবল ডিক্লেয়ার করা হলে, তা প্যাকেজের সব ফাংশন এবং প্রোসিডিউরের মধ্যে শেয়ার করা যায় (যদি তা প্যাকেজ স্পেসিফিকেশন থেকে অ্যাক্সেসযোগ্য হয়)।

  • Package Specification-এ ভেরিয়েবল ডিক্লেয়ার করা হলে এটি পাবলিক হয়ে ওঠে।
  • Package Body-এ ভেরিয়েবল প্রাইভেটভাবে ব্যবহৃত হতে পারে।

Syntax:

-- Package Specification (Declaration)
variable_name datatype;

-- Package Body (Implementation)
variable_name datatype := initial_value;

উদাহরণ:

-- Package Specification
CREATE OR REPLACE PACKAGE employee_pkg AS
   v_employee_count NUMBER;
END employee_pkg;

-- Package Body
CREATE OR REPLACE PACKAGE BODY employee_pkg AS
   v_employee_count NUMBER := 0; -- Initialize variable

   PROCEDURE increase_employee_count IS
   BEGIN
      v_employee_count := v_employee_count + 1;
   END increase_employee_count;
END employee_pkg;

Package Components Summary

  • Functions: কোড ব্লক যা একটি ইনপুট নিয়ে একটি মান রিটার্ন করে। সাধারণত ক্যালকুলেশন বা ডেটা প্রসেসিংয়ের জন্য ব্যবহৃত হয়।
  • Procedures: কোড ব্লক যা কিছু কার্য সম্পাদন করে কিন্তু কোন মান রিটার্ন করে না। এটি প্রক্রিয়া চালানোর জন্য ব্যবহৃত হয়।
  • Variables: ডেটা ধারণ করার জন্য ব্যবহৃত উপাদান, যা প্যাকেজে ঘোষিত হলে অন্যান্য ফাংশন এবং প্রোসিডিউরগুলির মধ্যে শেয়ার করা যায়।

এই উপাদানগুলি প্যাকেজের কাঠামো গঠনে ব্যবহৃত হয় এবং বিভিন্ন ধরনের ফাংশন, প্রোসিডিউর, ভেরিয়েবল এবং অন্যান্য ডেটা টাইপ দিয়ে কোডের পুনঃব্যবহারযোগ্যতা এবং কাঠামোগত সংগঠন নিশ্চিত করে।

Content added By

PL/SQL Package হল একটি প্রোগ্রাম ইউনিট যা একাধিক সম্পর্কিত procedure, function, variables, এবং types একত্রিত করে। এটি কোডের পুনঃব্যবহারযোগ্যতা এবং সংগঠন উন্নত করে এবং কমপ্লেক্স অ্যাপ্লিকেশনগুলিকে সহজে পরিচালিত করতে সহায়তা করে। একটি প্যাকেজের মধ্যে দুটি প্রধান অংশ থাকে:

  1. Package Specification (Specification)
  2. Package Body (Body)

১. Package Specification

Package Specification হল প্যাকেজের প্রকাশ্য অংশ যা প্যাকেজের কার্যকারিতা বা public interface এর বিবরণ দেয়। এতে প্যাকেজের সব ফাংশন, প্রোসিডিওর, কনস্ট্যান্ট এবং টাইপ ডিফিনিশন থাকে যেগুলি অন্য কোড বা ইউনিট থেকে অ্যাক্সেস করা যাবে।

২. Package Body

Package Body হল প্যাকেজের গোপন অংশ যেখানে প্যাকেজের কার্যকারিতা সংজ্ঞায়িত করা হয়। এটি Specification-এ ঘোষিত সকল ফাংশন ও প্রোসিডিওরকে বাস্তবায়ন করে এবং ডাটাবেসে প্রাসঙ্গিক কার্যক্রম পরিচালনা করে।


Package তৈরি: উদাহরণ

১. Package Specification (Specification)

CREATE OR REPLACE PACKAGE Employee_Package AS
  -- Declaration of variables
  v_employee_count NUMBER;

  -- Declaration of procedure
  PROCEDURE get_employee_count;

  -- Declaration of function
  FUNCTION get_employee_name (emp_id IN NUMBER) RETURN VARCHAR2;
END Employee_Package;
/

২. Package Body (Body)

CREATE OR REPLACE PACKAGE BODY Employee_Package AS

  -- Implementing the procedure
  PROCEDURE get_employee_count IS
  BEGIN
    SELECT COUNT(*) INTO v_employee_count FROM employees;
    DBMS_OUTPUT.PUT_LINE('Total Employees: ' || v_employee_count);
  END get_employee_count;

  -- Implementing the function
  FUNCTION get_employee_name (emp_id IN NUMBER) RETURN VARCHAR2 IS
    v_name VARCHAR2(50);
  BEGIN
    SELECT employee_name INTO v_name FROM employees WHERE employee_id = emp_id;
    RETURN v_name;
  END get_employee_name;

END Employee_Package;
/

ব্যাখ্যা:

  • Package Specification: এখানে প্যাকেজের বৈশিষ্ট্য ঘোষিত হয়েছে। এটি প্যাকেজের সকল পাবলিক ফাংশন, প্রোসিডিউর এবং ভেরিয়েবল ধারণ করে।
    • v_employee_count একটি ভেরিয়েবল যা মোট কর্মচারী সংখ্যা ধারণ করবে।
    • get_employee_count একটি প্রোসিডিউর যা কর্মচারীদের মোট সংখ্যা বের করবে এবং আউটপুট হিসেবে দেখাবে।
    • get_employee_name একটি ফাংশন যা একটি নির্দিষ্ট কর্মচারীর নাম রিটার্ন করবে।
  • Package Body: এখানে প্যাকেজের কার্যকারিতা বাস্তবায়িত হয়েছে।
    • get_employee_count প্রোসিডিউরটি employees টেবিল থেকে কর্মচারীদের সংখ্যা গণনা করে এবং সেটি DBMS_OUTPUT.PUT_LINE এর মাধ্যমে আউটপুট হিসেবে দেখায়।
    • get_employee_name ফাংশনটি employee_id দিয়ে employees টেবিল থেকে নির্দিষ্ট কর্মচারীর নাম রিটার্ন করে।

Package ব্যবহার:

প্যাকেজটি ব্যবহার করতে হলে আপনি তার ফাংশন এবং প্রোসিডিউরগুলো কল করতে পারেন।

১. Procedure Call

BEGIN
  Employee_Package.get_employee_count;
END;

২. Function Call

DECLARE
  v_name VARCHAR2(50);
BEGIN
  v_name := Employee_Package.get_employee_name(101);  -- Employee ID 101 এর নাম পাবেন
  DBMS_OUTPUT.PUT_LINE('Employee Name: ' || v_name);
END;

Package এর সুবিধা:

  1. কোডের পুনঃব্যবহারযোগ্যতা: একবার প্যাকেজ তৈরি করা হলে, তার ফাংশন ও প্রোসিডিউর অন্য স্থানে সহজে ব্যবহার করা যায়।
  2. সংগঠন: কোডের শ্রেণীবিভাগ ও সংগঠন উন্নত হয়, কারণ ফাংশন এবং প্রোসিডিউরগুলি সম্পর্কিত প্যাকেজে থাকে।
  3. পারফরম্যান্স উন্নতি: প্যাকেজের ভেরিয়েবলগুলি একবার মেমোরিতে লোড হলে সেগুলি পুনঃব্যবহার করা যায়, যা পারফরম্যান্স উন্নত করে।
  4. আন্তঃপ্যাকেজ যোগাযোগ: প্যাকেজের মধ্যে ভেরিয়েবল এবং ফাংশনগুলো সহজে অ্যাক্সেস করা যায়, যার ফলে কোডের মধ্যে আন্তঃযোগাযোগ সহজ হয়।

PL/SQL Package উদাহরণের সারাংশ:

  • Package Specification: প্যাকেজের পাবলিক ইন্টারফেস ঘোষিত হয়।
  • Package Body: কার্যকরী ফাংশন এবং প্রোসিডিউরগুলির বাস্তবায়ন।
  • Package ব্যবহার: অন্য PL/SQL ব্লক থেকে প্যাকেজের ফাংশন এবং প্রোসিডিউরগুলো কল করা যায়।

এই প্যাকেজ ব্যবস্থাপনা কোডিংকে আরো দক্ষ, সংগঠিত এবং পুনঃব্যবহারযোগ্য করে তোলে, যা বড় সিস্টেম ডেভেলপমেন্টে বিশেষভাবে গুরুত্বপূর্ণ।

Content added By
Promotion

Are you sure to start over?

Loading...