Functions এবং Procedures এর সাথে Parameters ব্যবস্থাপনা

PL/SQL এর Stored Procedures এবং Functions - পিএল/এসকিউএল (PL/SQL) - Database Tutorials

355

PL/SQL-এ Functions এবং Procedures উভয়ই খুব গুরুত্বপূর্ণ অবজেক্ট, যেগুলি কোড পুনঃব্যবহারযোগ্য এবং সংগঠিত করার জন্য ব্যবহৃত হয়। এই ফাংশন এবং প্রোসিডিউরগুলোতে Parameters ব্যবহার করার মাধ্যমে, ডেটা অ্যাক্সেস এবং প্রক্রিয়া করতে সহায়ক হয়। Parameters ব্যবস্থাপনা কার্যকরভাবে কোডের নমনীয়তা এবং পুনঃব্যবহারযোগ্যতা বাড়ায়।

ফাংশন এবং প্রোসিডিউরের মধ্যে পার্থক্য

  • Function:
    • একটি ফাংশন একটি ভ্যালু রিটার্ন করে। এটি সাধারণত একটি একক ভ্যালু বা একটি ফলাফল প্রদান করার জন্য ব্যবহৃত হয়।
    • ফাংশনকে সাধারণত SQL কোয়েরি বা অন্য কোন PL/SQL কোডের মধ্যে কল করা যায়।
  • Procedure:
    • একটি প্রোসিডিউর কোন ভ্যালু রিটার্ন করে না, তবে এটি কোনো নির্দিষ্ট কার্যপদ্ধতি সম্পাদন করে, যেমন ডেটাবেসে ইনসার্ট, আপডেট, অথবা ডিলিট।
    • প্রোসিডিউর সাধারণত প্রক্রিয়াগুলি সম্পাদন করার জন্য ব্যবহৃত হয় এবং এটি কল করার সময় আর্গুমেন্ট পাস করতে হয়।

Parameters Types

PL/SQL-এ ফাংশন এবং প্রোসিডিউরে তিন ধরনের প্যারামিটার ব্যবহৃত হয়:

  1. IN (Input Parameter):
    • IN প্যারামিটার হল ডিফল্ট প্যারামিটার, যা ফাংশন বা প্রোসিডিউরে ইনপুট হিসেবে প্রদান করা হয়। এটি শুধুমাত্র ফাংশন বা প্রোসিডিউরের ভিতরে পড়া যেতে পারে এবং তার মান পরিবর্তন করা যায় না।
    • উদাহরণ: ডেটা গ্রহণ করা, যেমন: এক্সিকিউট করার জন্য কোন মান প্রদান করা।
  2. OUT (Output Parameter):
    • OUT প্যারামিটার ব্যবহার করে ফাংশন বা প্রোসিডিউর থেকে ডেটা আউটপুট করা হয়। এটি ফাংশন বা প্রোসিডিউরের ভিতরে মান পরিবর্তন করতে দেয় এবং সেই পরিবর্তিত মান কলিং স্কোপে ফিরে আসে।
    • উদাহরণ: কোন ফলাফল প্রদান করা, যেমন কোন ক্যালকুলেশন বা ভ্যালু সেট করা।
  3. IN OUT (Input and Output Parameter):
    • IN OUT প্যারামিটার একে ইনপুট হিসেবে গ্রহণ করে এবং পরে আউটপুট প্রদান করে। অর্থাৎ, এটি ফাংশন বা প্রোসিডিউরে মান পাঠানোর পাশাপাশি সেই মান পরিবর্তনও করতে পারে।
    • উদাহরণ: মান পরিবর্তন করার প্রয়োজন যেখানে আপনি আর্গুমেন্ট পাঠান এবং পরবর্তীতে পরিবর্তিত মান পেতে চান।

Function এবং Procedure তৈরি এবং Parameters ব্যবস্থাপনা

এখন আমরা দেখব কীভাবে ফাংশন এবং প্রোসিডিউর তৈরি করা হয় এবং কীভাবে তাদের সাথে প্যারামিটার ব্যবস্থাপনা করা হয়।

1. Function তৈরি এবং Parameters ব্যবস্থাপনা

-- Function Example with Parameters
CREATE OR REPLACE FUNCTION get_employee_salary (
    p_emp_id IN employees.employee_id%TYPE
) RETURN employees.salary%TYPE
IS
    v_salary employees.salary%TYPE;
BEGIN
    -- Fetching salary from employees table based on emp_id
    SELECT salary INTO v_salary
    FROM employees
    WHERE employee_id = p_emp_id;
    
    -- Returning the salary value
    RETURN v_salary;
END;

এখানে, get_employee_salary ফাংশনটি IN প্যারামিটার হিসাবে p_emp_id গ্রহণ করে, এবং সেই কর্মচারীর বেতন রিটার্ন করে। এই ফাংশনটিকে employee_id অনুযায়ী বেতন বের করার জন্য ব্যবহৃত হবে।

ফাংশন কল করা:
DECLARE
    v_salary employees.salary%TYPE;
BEGIN
    v_salary := get_employee_salary(101);  -- Call the function with employee ID 101
    DBMS_OUTPUT.PUT_LINE('Employee Salary: ' || v_salary);
END;

এই কোডে, get_employee_salary ফাংশনটি কল করা হচ্ছে এবং প্যারামিটার হিসেবে 101 পাস করা হচ্ছে, যা ফাংশনের ভিতরে ব্যবহৃত হবে।


2. Procedure তৈরি এবং Parameters ব্যবস্থাপনা

-- Procedure Example with Parameters
CREATE OR REPLACE PROCEDURE update_employee_salary (
    p_emp_id IN employees.employee_id%TYPE,
    p_new_salary IN OUT employees.salary%TYPE
) IS
BEGIN
    -- Updating employee salary
    UPDATE employees
    SET salary = p_new_salary
    WHERE employee_id = p_emp_id;
    
    -- Returning the updated salary
    SELECT salary INTO p_new_salary
    FROM employees
    WHERE employee_id = p_emp_id;
    
    COMMIT;
END;

এখানে, update_employee_salary একটি প্রোসিডিউর যা দুটি প্যারামিটার নেয়:

  • p_emp_id (IN): এটি কর্মচারীর আইডি ইনপুট হিসেবে নেয়।
  • p_new_salary (IN OUT): এটি নতুন বেতন গ্রহণ করে এবং সেই বেতন পরিবর্তন করার পর আউটপুট হিসেবে প্রদান করে।
Procedure Call Example:
DECLARE
    v_emp_id employees.employee_id%TYPE := 101;
    v_new_salary employees.salary%TYPE := 5000;
BEGIN
    -- Call the procedure to update the salary
    update_employee_salary(v_emp_id, v_new_salary);
    
    -- Display the updated salary
    DBMS_OUTPUT.PUT_LINE('Updated Salary: ' || v_new_salary);
END;

এখানে, update_employee_salary প্রোসিডিউরটি কল করা হচ্ছে এবং v_emp_id এবং v_new_salary প্যারামিটার হিসাবে পাস করা হচ্ছে। প্রোসিডিউরটির মাধ্যমে বেতন আপডেট করার পর পরিবর্তিত বেতন আউটপুট হিসেবে পাওয়া যাবে।


Parameters ব্যবস্থাপনার সেরা অভ্যাস (Best Practices)

  1. IN প্যারামিটার ব্যবহার করা যখন শুধুমাত্র ডেটা প্রেরণ করতে হয়:
    যখন আপনি শুধুমাত্র ফাংশন বা প্রোসিডিউরে ডেটা পাঠাচ্ছেন এবং সেই ডেটা পরিবর্তন করা প্রয়োজন নয়, তখন IN প্যারামিটার ব্যবহার করা উচিত।
  2. OUT প্যারামিটার ব্যবহার করা যখন ফলাফল ফেরত দিতে হয়:
    প্রোসিডিউর বা ফাংশন থেকে যদি কোনো ফলাফল বা মান ফেরত দিতে হয়, তবে OUT প্যারামিটার ব্যবহার করুন।
  3. IN OUT প্যারামিটার ব্যবহার করা যখন ডেটা প্রেরণ এবং ফেরত দুইটাই করতে হয়:
    যখন আপনি কোন মান প্রেরণ করতে চান এবং সেই মানকে পরিবর্তন করে ফেরত চান, তখন IN OUT প্যারামিটার ব্যবহার করুন।
  4. Proper Data Types ব্যবহার করা:
    ফাংশন এবং প্রোসিডিউর তৈরি করার সময়, প্যারামিটার ডেটা টাইপের সাথে মিল রেখে সঠিক ডেটা টাইপ ব্যবহার করুন। এতে কোডের কার্যক্ষমতা এবং ডেটা সঠিকতা নিশ্চিত হয়।
  5. Default Values ব্যবহার করা:
    যখন কোনো প্যারামিটার অপরিহার্য না হয়, তখন আপনি ডিফল্ট মান নির্ধারণ করতে পারেন, যাতে কল করার সময় সেই প্যারামিটার না দিয়েও ফাংশন বা প্রোসিডিউরটি কল করা যায়।

উপসংহার

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

Content added By
Promotion

Are you sure to start over?

Loading...