DB2 Stored Procedures এবং Functions

Database Tutorials - ডিবি২ (DB2)
259
259

Stored Procedures এবং Functions হল DB2 ডেটাবেসে ব্যবহৃত বিশেষ প্রোগ্রাম যা ডেটাবেস অপারেশন স্বয়ংক্রিয় করতে, কর্মক্ষমতা বৃদ্ধি করতে এবং ডেটাবেসের সঙ্গে কাজ করার পদ্ধতি সহজ করতে ব্যবহৃত হয়। এগুলি SQL ভিত্তিক এবং সাধারণত ডেটাবেসের মধ্যে পুনরাবৃত্ত কার্যক্রম পরিচালনা করার জন্য তৈরি করা হয়। এখানে DB2 Stored Procedures এবং Functions এর সম্পর্কে বিস্তারিত আলোচনা করা হলো।


Stored Procedures

Stored Procedure একটি প্রোগ্রাম যা DB2 ডেটাবেসে সংরক্ষিত থাকে এবং SQL কুয়েরি বা অন্যান্য ডেটাবেস কার্যক্রমের সিরিজ চালায়। এটি ব্যবহারকারী বা অ্যাপ্লিকেশন থেকে আগত ইনপুট অনুযায়ী কিছু লজিক্যাল কার্যক্রম সম্পাদন করতে সক্ষম।

Stored Procedure এর সুবিধা

  • Performance Optimization: একাধিক SQL কুয়েরি এবং কার্যক্রমের মধ্যে অতি প্রয়োজনীয় কাজ গুলি একত্রে সম্পাদন করা যায়, যা সার্ভারের কার্যক্ষমতা বৃদ্ধি করে।
  • Reusability: একবার একটি স্টোরড প্রোসিডিউর তৈরি করার পর, এটি বারবার ব্যবহার করা যেতে পারে, যা কোড পুনঃব্যবহারযোগ্যতা নিশ্চিত করে।
  • Modularity: বিভিন্ন কার্যক্রম বা লজিককে আলাদা প্রোসিডিউরের মধ্যে ভাগ করা যায়, যা অ্যাপ্লিকেশনের কোডকে পরিষ্কার এবং সুসংগঠিত রাখে।
  • Error Handling: স্টোরড প্রোসিডিউরগুলিতে exception handling যুক্ত করা যায়, যা ত্রুটি সনাক্তকরণ এবং সমাধান করার প্রক্রিয়া সহজ করে।

Stored Procedure তৈরি করা

DB2 তে স্টোরড প্রোসিডিউর তৈরি করতে CREATE PROCEDURE কমান্ড ব্যবহার করা হয়।

উদাহরণ:

CREATE PROCEDURE CalculateTotalSales (IN customer_id INT, OUT total_sales DECIMAL)
LANGUAGE SQL
BEGIN
    SELECT SUM(sale_amount)
    INTO total_sales
    FROM sales
    WHERE customer_id = customer_id;
END;

এখানে:

  • IN customer_id ইনপুট প্যারামিটার, যা ফাংশনের আর্গুমেন্ট হিসেবে কাজ করে।
  • OUT total_sales আউটপুট প্যারামিটার, যেখানে ফাংশনটি ফলাফল ফেরত দিবে।

Stored Procedure কল করা

স্টোরড প্রোসিডিউর কল করার জন্য CALL কমান্ড ব্যবহার করা হয়।

CALL CalculateTotalSales(101, @total_sales);

এখানে, 101 হল ইনপুট প্যারামিটার (উদাহরণস্বরূপ, একটি গ্রাহক আইডি), এবং @total_sales আউটপুট প্যারামিটারকে ধারণ করতে ব্যবহৃত হয়।


Functions

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

Functions এর সুবিধা

  • Reusability: ফাংশন একবার তৈরি করা হলে তা বারবার ব্যবহার করা যায়।
  • Simplified Queries: ডেটাবেস কুয়েরি লেখার সময় ফাংশন ব্যবহার করা হলে, কুয়েরি আরও সহজ এবং স্বচ্ছ হয়।
  • Performance: ফাংশনগুলি সাধারণত দ্রুত কাজ করে, কারণ এগুলি ডেটাবেসে সংরক্ষিত এবং অপ্টিমাইজড থাকে।
  • Return Values: ফাংশনগুলো একটি মান ফেরত দেয়, যা অন্য কুয়েরি বা অ্যাপ্লিকেশনে ব্যবহার করা যেতে পারে।

Functions তৈরি করা

DB2 তে CREATE FUNCTION কমান্ড ব্যবহার করে ফাংশন তৈরি করা হয়।

উদাহরণ:

CREATE FUNCTION CalculateDiscount (price DECIMAL)
RETURNS DECIMAL
LANGUAGE SQL
BEGIN
    DECLARE discount DECIMAL;
    SET discount = price * 0.1;
    RETURN discount;
END;

এখানে:

  • price ইনপুট প্যারামিটার হিসেবে কাজ করে।
  • discount হল সেই মান যা ফাংশনটি ফেরত দিবে।

Function কল করা

ফাংশন কল করার জন্য সরাসরি SQL কুয়েরিতে ফাংশনটিকে কল করা যায়।

SELECT product_name, price, CalculateDiscount(price) AS discount
FROM products;

এখানে, CalculateDiscount(price) ফাংশনটি price ইনপুট প্যারামিটার ব্যবহার করে ডিসকাউন্টের পরিমাণ গণনা করবে।


Stored Procedures এবং Functions এর মধ্যে পার্থক্য

বিষয়Stored ProcedureFunction
ফলাফল ফেরত দেওয়াস্টোরড প্রোসিডিউর কোনো মান ফেরত দেয় না, তবে আউটপুট প্যারামিটার ব্যবহার করা হয়।ফাংশন একক মান ফেরত দেয় (যেমন, DECIMAL, INT)
ব্যবহারস্টোরড প্রোসিডিউর সাধারণত বড় লজিক এবং SQL স্টেটমেন্টগুলির জন্য ব্যবহৃত হয়।ফাংশন সাধারণত ছোট একক লজিকের জন্য ব্যবহৃত হয়।
কমান্ড কলCALL কমান্ড দিয়ে কল করা হয়।SQL কুয়েরি বা অন্য ফাংশনের মধ্যে কল করা হয়।
প্যারামিটারইনপুট, আউটপুট অথবা ইনপুট/আউটপুট প্যারামিটার হতে পারে।শুধুমাত্র ইনপুট প্যারামিটার হতে পারে।
ডেটাবেসে ব্যবহারের ক্ষেত্রেএটি ট্রানজেকশন বা একাধিক SQL অপারেশন সম্পাদনের জন্য উপযুক্ত।একক SQL কাজ সম্পাদন করার জন্য উপযুক্ত।

Stored Procedures এবং Functions এর ব্যবহার

  1. Stored Procedures:
    • দীর্ঘ বা জটিল SQL লজিক সমর্থন করার জন্য।
    • একাধিক ডেটাবেস টেবিল বা কুয়েরির সাথে কাজ করার জন্য।
    • একাধিক কার্যক্রম বা ট্রানজেকশন পরিচালনা করার জন্য।
  2. Functions:
    • একটি একক কার্য সম্পাদন করার জন্য।
    • SQL কুয়েরিতে নির্দিষ্ট মান গণনা বা প্রয়োগ করার জন্য।
    • সহজ এবং পুনরাবৃত্তি হতে পারে এমন লজিকের জন্য।

সারসংক্ষেপ

  • Stored Procedures এবং Functions DB2 ডেটাবেসের কার্যকারিতা ও কার্যক্রম স্বয়ংক্রিয় করতে ব্যবহৃত হয়।
  • Stored Procedures ডেটাবেস অপারেশনগুলির একটি সিরিজ পরিচালনা করে এবং আউটপুট প্যারামিটার ব্যবহার করে মান ফেরত দেয় না।
  • Functions সাধারণত ছোট লজিকের জন্য ব্যবহৃত হয় এবং একটি একক মান ফেরত দেয়।

এগুলো ডেটাবেসের মধ্যে পুনরাবৃত্তি কাজগুলির জন্য অত্যন্ত কার্যকরী এবং ডেটাবেস পারফরম্যান্সের উন্নতিতে সাহায্য করে।

common.content_added_by

Stored Procedures কী এবং কেন ব্যবহার করবেন?

235
235

Stored Procedures কী?

Stored Procedures হল পূর্বনির্ধারিত SQL কুয়েরি বা অপারেশনগুলোর একটি সেট, যা ডেটাবেসের ভিতরে সংরক্ষিত এবং পরিচালিত হয়। এগুলি একাধিক SQL কুয়েরি, শর্ত বা লজিকাল অপারেশন নিয়ে গঠিত, যেগুলি পূর্বে একবার সংজ্ঞায়িত করা হয় এবং পরে প্রয়োজনমতো একাধিক বার চালানো যায়। একটি Stored Procedure মূলত একটি নামকৃত SQL স্ক্রিপ্ট যা ডেটাবেস সার্ভারে রান করা হয়, এবং এটি ব্যবহারকারী বা অ্যাপ্লিকেশন দ্বারা কল করা যায়।

Stored Procedure সাধারণত একটি ডেটাবেসে সংরক্ষিত এবং পুনরায় ব্যবহারের জন্য তৈরি করা হয়, যার ফলে ডেটাবেস অ্যাপ্লিকেশনটি বেশি কার্যকরী এবং সহজ হয়।


Stored Procedures এর সুবিধা

  1. পারফরম্যান্স বৃদ্ধি:
    • Stored Procedures ডেটাবেসে একবার কম্পাইল হয়ে সংরক্ষিত হয়, যার ফলে পুনরায় প্রয়োগের সময় কোন ধরনের কম্পাইলিং প্রয়োজন হয় না। এটি কুয়েরির কার্যকারিতা এবং পারফরম্যান্স বাড়িয়ে তোলে।
  2. কোড পুনঃব্যবহারযোগ্যতা:
    • একাধিক অ্যাপ্লিকেশন বা ব্যবহারকারী একটি Stored Procedure ব্যবহার করতে পারে, যার ফলে কোডের পুনঃব্যবহারযোগ্যতা নিশ্চিত হয়।
  3. ডেটাবেস স্তরের লজিক:
    • ডেটাবেসের ভিতরে লজিকাল কাজ করা সম্ভব হয়, যার ফলে অ্যাপ্লিকেশন লেভেলে বেশি কাজ করার প্রয়োজন হয় না।
  4. নিরাপত্তা:
    • Stored Procedure এর মাধ্যমে ডেটাবেসের কিছু লজিকাল কাজ এক্সিকিউট করা যায়, তবে সরাসরি টেবিল বা ডেটা অ্যাক্সেস করার অনুমতি না দিয়ে। এর ফলে ডেটাবেসের নিরাপত্তা বেড়ে যায়।
  5. ত্রুটি হ্যান্ডলিং:
    • Stored Procedures ত্রুটি হ্যান্ডলিং এবং ট্রানজেকশন ব্যবস্থাপনা সহজ করে তোলে। ডেটাবেস অপারেশনগুলো একটি নির্দিষ্ট ফ্রেমওয়ার্কে পরিচালিত হয়, যার ফলে ত্রুটি কম হয়।

Stored Procedures ব্যবহার করার কারণ

  1. ডেটাবেস অপারেশনগুলো একত্রিত করা:
    • একাধিক SQL কুয়েরি বা ডেটাবেস অপারেশনগুলো একত্রিত করার জন্য একটি Stored Procedure ব্যবহার করা হয়, যাতে এগুলো একযোগভাবে কার্যকরী হয়।
  2. ট্রানজেকশন পরিচালনা:
    • একাধিক ডেটাবেস অপারেশন একটি ট্রানজেকশনের মধ্যে পরিচালনা করা যেতে পারে। এর ফলে, একাধিক অপারেশন সফল না হলে সবকিছু রোলব্যাক করা যায়, যা ডেটাবেসের একসাথে সঠিকতা এবং স্থিতিস্থাপকতা নিশ্চিত করে।
  3. শর্তযুক্ত লজিক প্রয়োগ:
    • Stored Procedure ব্যবহার করে শর্তযুক্ত লজিক (যেমন IF, CASE বা LOOP) প্রয়োগ করা যায়, যা SQL কুয়েরি বা অপারেশনের মধ্যে আরও লজিক্যাল ও কাঠামোগত অপারেশনগুলো তৈরি করতে সাহায্য করে।
  4. ডেটাবেস অ্যাপ্লিকেশনের জটিলতা কমানো:
    • Stored Procedure ব্যবহার করলে, অ্যাপ্লিকেশন কোড থেকে জটিল SQL কুয়েরি এবং লজিক সরানো যায়, এবং ডেটাবেস স্তরে এগুলো পরিচালনা করা সম্ভব হয়।
  5. নেটওয়ার্ক ট্র্যাফিক কমানো:
    • বড় এবং জটিল SQL অপারেশনগুলো একবারে ডেটাবেসে চালানো হয়, যা নেটওয়ার্ক ট্র্যাফিক কমিয়ে দেয় এবং ক্লায়েন্ট-সার্ভার ইন্টারঅ্যাকশন দ্রুত করে তোলে।

Stored Procedure তৈরি করার উদাহরণ

ধরা যাক, আমাদের একটি employees টেবিল আছে এবং আমরা এই টেবিল থেকে নির্দিষ্ট department_id অনুসারে সমস্ত কর্মচারী (employees) ফেচ করতে চাই। এর জন্য একটি Stored Procedure তৈরি করা যায়।

Stored Procedure তৈরি করা:

CREATE PROCEDURE get_employees_by_department(IN dept_id INT)
    LANGUAGE SQL
    BEGIN
        SELECT employee_id, first_name, last_name
        FROM employees
        WHERE department_id = dept_id;
    END;

এই উদাহরণে, get_employees_by_department নামে একটি Stored Procedure তৈরি করা হয়েছে, যেটি dept_id ইনপুট প্যারামিটার হিসেবে নেয় এবং employees টেবিল থেকে সেই বিভাগের কর্মচারীদের তথ্য বের করে।

Stored Procedure কল করা:

CALL get_employees_by_department(10);

এখানে, 10 হচ্ছে ইনপুট প্যারামিটার হিসেবে যে department_id এর কর্মচারীদের তথ্য আমরা চাই।


Stored Procedure-এর উন্নত বৈশিষ্ট্য

  1. IN, OUT, INOUT প্যারামিটার:

    • Stored Procedure তে ইনপুট (IN), আউটপুট (OUT), এবং ইনপুট/আউটপুট (INOUT) প্যারামিটার ব্যবহার করা যায়।

    উদাহরণ:

    CREATE PROCEDURE update_employee_salary(IN emp_id INT, OUT new_salary DECIMAL)
    BEGIN
        UPDATE employees SET salary = salary * 1.10 WHERE employee_id = emp_id;
        SELECT salary INTO new_salary FROM employees WHERE employee_id = emp_id;
    END;
    
  2. Error Handling:

    • DB2-এ, Stored Procedure তে ত্রুটি হ্যান্ডলিং DECLARE CONTINUE HANDLER দ্বারা করা যায়।

    উদাহরণ:

    CREATE PROCEDURE safe_update_employee(IN emp_id INT, IN new_salary DECIMAL)
    BEGIN
        DECLARE CONTINUE HANDLER FOR SQLEXCEPTION
        BEGIN
            -- Handle error
            ROLLBACK;
        END;
        UPDATE employees SET salary = new_salary WHERE employee_id = emp_id;
        COMMIT;
    END;
    

সারসংক্ষেপ

  • Stored Procedures হল পূর্বনির্ধারিত SQL কুয়েরির একটি সেট যা ডেটাবেসে সংরক্ষিত এবং একাধিক বার ব্যবহার করা যায়।
  • এগুলি পারফরম্যান্স বাড়ানোর জন্য, কোড পুনঃব্যবহারযোগ্যতা নিশ্চিত করার জন্য, নিরাপত্তা এবং ত্রুটি হ্যান্ডলিংয়ের জন্য গুরুত্বপূর্ণ।
  • Stored Procedures DB2 ডেটাবেসের কার্যকারিতা, নিরাপত্তা এবং স্থিতিস্থাপকতা নিশ্চিত করতে সহায়ক এবং এগুলির মাধ্যমে SQL কুয়েরির কার্যকারিতা অপ্টিমাইজ করা যায়।
common.content_added_by

DB2 তে Stored Procedures তৈরি এবং ব্যবহার

259
259

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


Stored Procedures এর সুবিধা

  1. কোড পুনঃব্যবহারযোগ্যতা: Stored Procedure একবার তৈরি করে পরবর্তীতে বার বার ব্যবহার করা যায়, যেটি কোড পুনঃব্যবহারের সুবিধা দেয়।
  2. পারফরম্যান্স উন্নয়ন: DB2 Stored Procedures প্রি-কম্পাইলড হওয়ায় এগুলি দ্রুত সম্পাদিত হয়, যা কুয়েরি প্রক্রিয়াকরণের গতি বৃদ্ধি করে।
  3. ডেটাবেস সুরক্ষা: Stored Procedure এর মাধ্যমে, ব্যবহারকারীরা সরাসরি ডেটাবেস অবজেক্টে অ্যাক্সেস করতে পারে না; তারা শুধুমাত্র প্রি-ডিফাইন্ড স্টোরড প্রসিডিউরগুলির মাধ্যমে ডেটাবেসের সঙ্গে ইন্টারঅ্যাক্ট করতে পারে।
  4. ডেটাবেস লজিক সার্ভার সাইডে রাখে: এটি ডেটাবেসের লজিক সার্ভার সাইডে রাখার মাধ্যমে ক্লায়েন্ট সাইডের লোড কমিয়ে দেয়।

DB2 তে Stored Procedures তৈরি

DB2 তে Stored Procedure তৈরি করার জন্য CREATE PROCEDURE স্টেটমেন্ট ব্যবহার করা হয়। সাধারণত, একটি Stored Procedure তৈরি করতে SQL ভাষায় স্টেটমেন্ট লিখতে হয়, এবং প্রয়োজনে PL/SQL ব্যবহার করা যেতে পারে।

উদাহরণ: একটি Stored Procedure তৈরি করা

ধরা যাক, আমাদের একটি employees টেবিল রয়েছে, এবং আমরা একটি Stored Procedure তৈরি করতে চাই যা একটি নির্দিষ্ট employee_id অনুযায়ী employee_name ফেরত দিবে।

CREATE PROCEDURE get_employee_name(IN emp_id INT, OUT emp_name VARCHAR(100))
LANGUAGE SQL
BEGIN
   SELECT employee_name
   INTO emp_name
   FROM employees
   WHERE employee_id = emp_id;
END;

এখানে:

  • IN emp_id INT: এটি ইনপুট প্যারামিটার, যা employee_id নেওয়ার জন্য ব্যবহৃত হবে।
  • OUT emp_name VARCHAR(100): এটি আউটপুট প্যারামিটার, যা employee_name ফেরত দেবে।
  • LANGUAGE SQL: এটি নির্দেশ করে যে Stored Procedure টি SQL ভাষায় লেখা হয়েছে।
  • BEGIN...END: এই ব্লকের মধ্যে SQL স্টেটমেন্টগুলি থাকবে যা স্টোরড প্রসিডিউরের কার্যকলাপ নির্ধারণ করবে।

DB2 তে Stored Procedures ব্যবহার

Stored Procedure ব্যবহার করতে হলে, সেগুলিকে CALL কমান্ড দিয়ে ডাকা হয়। এর মাধ্যমে আপনি নির্দিষ্ট প্যারামিটার পাঠিয়ে স্টোরড প্রসিডিউর চালাতে পারেন।

উদাহরণ: Stored Procedure কল করা

ধরা যাক, আমরা আগের get_employee_name স্টোরড প্রসিডিউরটি কল করতে চাই:

DECLARE emp_name VARCHAR(100);
CALL get_employee_name(101, emp_name);
SELECT emp_name FROM SYSIBM.SYSDUMMY1;

এখানে:

  • DECLARE: এটি একটি ভ্যারিয়েবল ঘোষণা করে, যা আউটপুট হিসেবে ব্যবহার করা হবে।
  • CALL get_employee_name(101, emp_name): এই কমান্ডটি Stored Procedure কল করে, যেখানে 101 হলো ইনপুট প্যারামিটার (employee_id) এবং emp_name আউটপুট প্যারামিটার হিসেবে কাজ করবে।
  • SELECT: আউটপুটের মান পরীক্ষা করতে, আমরা SYSIBM.SYSDUMMY1 টেবিল থেকে emp_name ভ্যারিয়েবল নির্বাচন করেছি।

Stored Procedures এর সুবিধা এবং ব্যবহার

1. প্যারামিটার ব্যবহার:

  • Stored Procedure-এ প্যারামিটার ব্যবহার করে, আপনি ইনপুট এবং আউটপুট কাস্টমাইজ করতে পারেন।
  • DB2-তে IN, OUT, এবং INOUT প্যারামিটার রয়েছে:
    • IN: ইনপুট প্যারামিটার, যা স্টোরড প্রসিডিউরে ডেটা পাঠানো হয়।
    • OUT: আউটপুট প্যারামিটার, যা স্টোরড প্রসিডিউর থেকে ডেটা ফেরত আনে।
    • INOUT: এই প্যারামিটারটি ইনপুট এবং আউটপুট হিসেবে কাজ করে।

2. বিভিন্ন কার্যকলাপ সম্পাদন:

  • DB2-এ স্টোরড প্রসিডিউর ব্যবহার করে আপনি জটিল কুয়েরি, ডেটাবেস অপারেশন, টানেলিং, লজিক্যাল অপারেশন ইত্যাদি একযোগভাবে পরিচালনা করতে পারেন।

3. ব্যবহারিক উদাহরণ:

  • পণ্য পরিসংখ্যান: একটি স্টোরড প্রসিডিউর তৈরি করতে পারেন যা পণ্যের মোট বিক্রয়, গড় মূল্য ইত্যাদি গণনা করবে।
  • বিক্রেতার ডেটা বিশ্লেষণ: একটি স্টোরড প্রসিডিউর তৈরি করা যেতে পারে যা বিক্রেতার উপর নির্ভরশীল তথ্য বের করবে যেমন কোন বিক্রেতার কী পরিমাণ পণ্য বিক্রি হয়েছে।

Stored Procedures এর পারফরম্যান্স অপ্টিমাইজেশন

  1. প্রি-কম্পাইলড কোড:
    • স্টোরড প্রসিডিউর সাধারণত প্রি-কম্পাইলড হয়, যার ফলে এটি দ্রুত কার্যকরী হয় কারণ কোডটি আগে থেকেই কম্পাইল হয়ে ডেটাবেস সার্ভারে সংরক্ষিত থাকে।
  2. ফাংশন এবং ট্রিগার ব্যবহার:
    • আপনি Stored Procedures এর মধ্যে functions এবং triggers ব্যবহার করতে পারেন যাতে আরও উন্নত পারফরম্যান্স এবং কার্যকারিতা পাওয়া যায়।
  3. ক্যাশিং:
    • DB2 ক্যাশিং ব্যবহার করে স্টোরড প্রসিডিউরের পারফরম্যান্স উন্নত করতে পারে, যার ফলে বারবার একই কাজের জন্য সিস্টেম পুনরায় কাজ করতে হবে না।

সারসংক্ষেপ

DB2 তে Stored Procedures তৈরি এবং ব্যবহার করা হয় ডেটাবেসে কার্যক্রম অটোমেট করার জন্য এবং কোড পুনঃব্যবহারযোগ্যতা বাড়ানোর জন্য। এটি ডেটাবেস অপারেশনগুলি দ্রুত করতে সহায়ক এবং ডেটাবেসের সিকিউরিটি উন্নত করে। Stored Procedures তৈরি করার জন্য CREATE PROCEDURE কমান্ড ব্যবহার করা হয় এবং এগুলিকে কল করার জন্য CALL কমান্ড ব্যবহার করা হয়। DB2 তে Stored Procedures পারফরম্যান্স উন্নত করতে এবং ডেটাবেস লজিক সার্ভার সাইডে রাখতে কার্যকরী সমাধান।

common.content_added_by

User Defined Functions (UDF) তৈরি করা

198
198

User Defined Functions (UDF) DB2-এ একটি শক্তিশালী বৈশিষ্ট্য যা ব্যবহারকারীদের তাদের নিজস্ব ফাংশন তৈরি করার সুযোগ দেয়। UDF তৈরি করে আপনি নির্দিষ্ট কাজগুলোকে পুনরায় ব্যবহারযোগ্য ফাংশনে পরিণত করতে পারেন। এর মাধ্যমে আপনি প্রোগ্রামিং লজিক এবং ক্যালকুলেশনকে আরও নমনীয় এবং শক্তিশালী করতে পারেন। DB2-এ UDF তৈরি করার জন্য SQL, C, C++, অথবা Java ব্যবহার করা যেতে পারে।


DB2 UDF কী?

User Defined Functions (UDF) হল ফাংশন যা DB2 ডেটাবেসের জন্য ব্যবহারকারী তৈরি করে এবং কাস্টম ক্যালকুলেশন, লজিকাল অপারেশন বা ডেটাবেস অপারেশন সম্পাদন করতে ব্যবহৃত হয়। UDF-এর সাহায্যে, আপনি আপনার ডেটাবেসে কাস্টম ফাংশন তৈরি করতে পারেন যা SQL কোডের মধ্যে ব্যবহার করা যায়।

UDF তৈরি করার ধাপ

DB2-এ UDF তৈরি করার জন্য আপনাকে নিচের ধাপগুলো অনুসরণ করতে হবে:


১. UDF এর ধরন নির্বাচন

DB2-এ তিন ধরনের UDF তৈরি করা যেতে পারে:

  1. Scalar Function: একটি একক মান ফেরত দেয়।
  2. Table Function: একটি টেবিল আউটপুট প্রদান করে।
  3. Aggregate Function: একটি গ্রুপের উপর গণনা বা ক্যালকুলেশন করে এবং একটি একক মান ফেরত দেয়।

২. SQL দিয়ে Scalar Function তৈরি করা

Scalar UDF হল এমন একটি ফাংশন যা একক আর্গুমেন্ট নেয় এবং একটি একক মান ফেরত দেয়।

উদাহরণ: ধরা যাক, আপনি একটি UDF তৈরি করতে চান যা দুটি সংখ্যা যোগ করবে। এর জন্য SQL ব্যবহার করে Scalar UDF তৈরি করা যাবে।

CREATE FUNCTION add_numbers (num1 INT, num2 INT)
RETURNS INT
LANGUAGE SQL
BEGIN
   RETURN num1 + num2;
END;

এটি একটি Scalar UDF যা দুটি ইনপুট প্যারামিটার (num1 এবং num2) গ্রহণ করে এবং তাদের যোগফল ফেরত দেয়।

ব্যবহার:

SELECT add_numbers(5, 10) FROM sysibm.sysdummy1;

এই কুয়েরি 5 এবং 10 যোগ করে ১৫ ফেরত দিবে।


৩. C অথবা C++ দিয়ে Scalar Function তৈরি করা

DB2-এ C বা C++ ব্যবহার করে UDF তৈরি করার জন্য আপনাকে ডেভেলপমেন্ট এনভায়রনমেন্ট সেটআপ করতে হবে। এর জন্য IBM DB2 UDF Development Kit (UDK) প্রয়োজন। এটি আপনার সিস্টেমে C বা C++ কোডে ফাংশন লেখা এবং কম্পাইল করতে সাহায্য করে।

C UDF উদাহরণ: ধরা যাক, আমরা একটি C ভাষায় ফাংশন তৈরি করতে চাই যা দুটি পূর্ণসংখ্যার গুণফল ফেরত দেবে।

#include "sqludf.h"

SQLRETURN multiply_numbers (SQLUDF_ARGS *args, SQLRETURN *ret)
{
    SQLINTEGER num1 = SQLGetUDFParam(args, 0);
    SQLINTEGER num2 = SQLGetUDFParam(args, 1);
    return num1 * num2;
}

এই কোডটি দুটি পূর্ণসংখ্যার গুণফল ফেরত দেবে। আপনি এটি কম্পাইল করে DB2-এ UDF হিসেবে রেজিস্টার করতে পারেন।


৪. Table Function তৈরি করা

Table Function একটি এমন UDF যা টেবিল আউটপুট দেয় এবং এটি সাধারণত কাস্টম ডেটা বা জটিল ডেটাবেস লজিকের জন্য ব্যবহৃত হয়।

উদাহরণ: ধরা যাক, আপনি এমন একটি UDF তৈরি করতে চান যা একটি কলামে নির্দিষ্ট মান অনুসারে ডেটা ফেরত দেয়।

CREATE FUNCTION get_employees_by_department (dept_id INT)
RETURNS TABLE (employee_id INT, first_name VARCHAR(50), last_name VARCHAR(50))
LANGUAGE SQL
BEGIN
   RETURN (SELECT employee_id, first_name, last_name 
           FROM employees
           WHERE department_id = dept_id);
END;

এটি department_id প্যারামিটার গ্রহণ করবে এবং ঐ বিভাগের কর্মচারীদের তথ্য একটি টেবিল আকারে ফেরত দেবে।

ব্যবহার:

SELECT * FROM TABLE(get_employees_by_department(10)) AS employee_list;

এটি department_id 10 এর সকল কর্মচারীর তথ্য একটি টেবিল আকারে ফেরত দেবে।


৫. Aggregate Function তৈরি করা

Aggregate Function সাধারণত গ্রুপভিত্তিক গণনা বা সারণী তৈরি করতে ব্যবহৃত হয়। এটি একাধিক রেকর্ডের উপর অপারেশন সম্পাদন করে এবং একটি একক ফলাফল দেয়।

উদাহরণ: ধরা যাক, আপনি একটি কাস্টম অ্যাগ্রিগেট ফাংশন তৈরি করতে চান যা গ্রাহকদের মধ্যে সর্বোচ্চ বেতন ফেরত দিবে।

CREATE FUNCTION max_salary (num1 INT, num2 INT)
RETURNS INT
LANGUAGE SQL
BEGIN
   IF num1 > num2 THEN
      RETURN num1;
   ELSE
      RETURN num2;
   END IF;
END;

এটি num1 এবং num2 এর মধ্যে সর্বোচ্চ মান ফেরত দিবে। এই ফাংশনটি গ্রুপের মধ্যে ব্যবহার করা যাবে।

ব্যবহার:

SELECT department_id, max_salary(MAX(salary), 0) 
FROM employees
GROUP BY department_id;

এটি প্রতিটি বিভাগের জন্য সর্বোচ্চ বেতন প্রদান করবে।


৬. UDF এর Deployment

একবার UDF তৈরি হয়ে গেলে, আপনি সেই ফাংশনটিকে ডেটাবেসে ডেপ্লয় করতে পারেন। ডেপ্লয় করার জন্য নিম্নলিখিত SQL কমান্ড ব্যবহার করা যেতে পারে:

CREATE FUNCTION function_name (parameters)
RETURNS return_type
LANGUAGE language
[DETERMINISTIC | NOT DETERMINISTIC]
[NO EXTERNAL ACTION | EXTERNAL ACTION]
[CONTAINS SQL | NO SQL]
[SQL DATA ACCESS | NO SQL DATA ACCESS]
[INLINE | NO INLINE]

৭. UDF মুছে ফেলা

যদি কোনো UDF আর প্রয়োজন না থাকে, তাহলে আপনি DROP FUNCTION কমান্ড দিয়ে ফাংশনটি মুছে ফেলতে পারেন।

উদাহরণ:

DROP FUNCTION function_name;

সারসংক্ষেপ

DB2-এ User Defined Functions (UDF) তৈরি করার মাধ্যমে আপনি ডেটাবেসের কার্যক্রম এবং ক্যালকুলেশনকে কাস্টমাইজ করতে পারেন। UDF এর মাধ্যমে আপনি scalar, table, এবং aggregate ফাংশন তৈরি করতে পারেন। SQL, C, C++, বা Java দিয়ে UDF তৈরি করা সম্ভব, এবং সেগুলো ডেটাবেসের কার্যক্ষমতা এবং নমনীয়তা বাড়াতে সাহায্য করে। DB2 UDF আপনাকে নির্দিষ্ট ডেটা অপারেশনকে পুনরায় ব্যবহারযোগ্য ফাংশনে রূপান্তরিত করতে সাহায্য করে, যা ডেটাবেসের পারফরম্যান্স এবং কার্যকারিতা উন্নত করে।

common.content_added_by

Stored Procedures Performance Optimization

229
229

DB2 Stored Procedures হল ডেটাবেসে প্রোগ্রামেবল অবজেক্ট যা ডেটাবেস অপারেশন যেমন কুয়েরি, ইনসার্ট, আপডেট এবং ডিলিট কার্যক্রম স্বয়ংক্রিয়ভাবে পরিচালনা করতে সাহায্য করে। এগুলি খুবই গুরুত্বপূর্ণ ডেটাবেস ম্যানেজমেন্টে, কারণ এগুলি ডেটাবেস সার্ভারে ক্লায়েন্ট এবং অ্যাপ্লিকেশন থেকে অ্যাক্সেস করা হয়। তবে, Stored Procedures এর পারফরম্যান্স অপ্টিমাইজ করা অত্যন্ত গুরুত্বপূর্ণ, যাতে ডেটাবেসের কর্মক্ষমতা বজায় থাকে। এখানে DB2 Stored Procedures পারফরম্যান্স অপ্টিমাইজ করার বিভিন্ন কৌশল এবং টিপস আলোচনা করা হলো।


১. ট্রানজেকশন ম্যানেজমেন্ট অপ্টিমাইজেশন

Stored Procedures সাধারনত ট্রানজেকশনগুলির মধ্যে চলে, তাই সঠিক ট্রানজেকশন ম্যানেজমেন্ট অত্যন্ত গুরুত্বপূর্ণ। দীর্ঘস্থায়ী ট্রানজেকশন ব্যবহারের পরিবর্তে ছোট ছোট ট্রানজেকশন ব্যবহারের মাধ্যমে পারফরম্যান্স বাড়ানো যায়।

টিপ:

  • Commit এবং Rollback: যেখানে প্রয়োজন, সেখানে দ্রুত COMMIT এবং ROLLBACK ব্যবহার করুন।

    COMMIT;
    
  • Savepoints ব্যবহার করা: ট্রানজেকশনের মধ্যে SAVEPOINT ব্যবহার করে, আপনি ডেটাবেসের মধ্যে একটি নির্দিষ্ট অবস্থায় ফিরে যেতে পারেন।

    SAVEPOINT my_savepoint;
    

২. Cursor ব্যবস্থাপনা

Stored Procedures-এ Cursors ব্যবহার করা হয় ডেটাবেসের মধ্যে একাধিক রেকর্ড প্রক্রিয়া করার জন্য। কিন্তু ভুলভাবে Cursors ব্যবহারের কারণে পারফরম্যান্স নষ্ট হতে পারে।

টিপ:

  • Explicit Cursor এবং Implicit Cursor এর মধ্যে পার্থক্য বুঝে ব্যবহার করুন। ইম্প্লিসিট কাস্টমার কুয়েরি এক্সিকিউট করার জন্য সঠিক কিন্তু জটিল কুয়েরির জন্য এক্সপ্লিসিট কাস্টমার ব্যবহার করুন।
  • FETCH অপারেশনটি সঠিকভাবে ব্যবহার করুন এবং যেহেতু এটি স্লো হতে পারে, তাই FETCH ONLY NECESSARY RECORDS নিন।

    DECLARE my_cursor CURSOR FOR my_query;
    OPEN my_cursor;
    FETCH NEXT FROM my_cursor INTO :var1, :var2;
    CLOSE my_cursor;
    

৩. শুধুমাত্র প্রয়োজনীয় কলাম নির্বাচন করা

Stored Procedure এর কুয়েরি থেকে সবসময় প্রয়োজনীয় কলামগুলোই নির্বাচন করুন। অবাঞ্ছিত ডেটা গ্রহণ করলে স্টোরেজ, প্রসেসিং টাইম এবং পারফরম্যান্স ক্ষতিগ্রস্ত হতে পারে।

টিপ:

  • কেবলমাত্র প্রয়োজনীয় কলামগুলিই SELECT করুন।

    SELECT EmployeeID, EmployeeName FROM Employees;
    
  • WHERE ক্লজ ব্যবহার: WHERE ক্লজ ব্যবহার করে শুধুমাত্র সেই রেকর্ডগুলো নির্বাচন করুন যা কার্যকরী।

    SELECT * FROM Employees WHERE Salary > 50000;
    

৪. চলন্ত কুয়েরি অপ্টিমাইজেশন

Stored Procedures এ চলন্ত কুয়েরি (Dynamic SQL) ব্যবহার করা যেতে পারে, তবে সেগুলি সঠিকভাবে অপ্টিমাইজ করতে হবে। অনেক ক্ষেত্রেই ডায়নামিক SQL পারফরম্যান্সে নেতিবাচক প্রভাব ফেলতে পারে।

টিপ:

  • Prepare Statement এবং Execute Immediate ব্যবহার করে চলন্ত কুয়েরির পারফরম্যান্স উন্নত করুন:

    PREPARE stmt FROM 'SELECT * FROM Employees WHERE Salary > ?';
    EXECUTE stmt USING 50000;
    
  • STMT_CACHE কনফিগারেশনে ক্যাশিং ব্যবহার করুন, যা SQL স্টেটমেন্ট কনফিগারেশন সংরক্ষণ করে, যাতে প্রতিবার একই কুয়েরি এক্সিকিউট না হয়।

৫. ভালোভাবে ডেটাবেস কনফিগারেশন এবং অপ্টিমাইজেশন

ডেটাবেস কনফিগারেশন অনেক সময় Stored Procedures এর পারফরম্যান্সে প্রভাব ফেলে। এটি মেমরি, ইনডেক্স, এবং কুয়েরি অপ্টিমাইজেশনের সাথে সম্পর্কিত।

টিপ:

  • Buffer Pools এবং Sort Heaps অপ্টিমাইজ করুন, যা কুয়েরি এক্সিকিউশনের জন্য মেমরি প্রদান করে:

    db2 update dbm cfg using DB2BUFFERPOOLSZ 4096
    
  • Indexing: ডেটা প্রক্রিয়াকরণের জন্য ইনডেক্স সঠিকভাবে তৈরি করুন। ভুলভাবে ইনডেক্স তৈরি করলে পারফরম্যান্সে নেতিবাচক প্রভাব পড়তে পারে।

৬. প্রাথমিক কী এবং ফরেন কী কনস্ট্রেইন্ট অপ্টিমাইজেশন

Stored Procedures তৈরি করার সময় Primary Key এবং Foreign Key কনস্ট্রেইন্ট সঠিকভাবে ব্যবহার করুন, কারণ এগুলো ডেটার ইন্টিগ্রিটি রক্ষা করে।

টিপ:

  • Primary Key এবং Foreign Key কনস্ট্রেইন্ট অবশ্যই উপযুক্তভাবে সেট করুন, তবে যতটুকু সম্ভব অন্যান্য কনস্ট্রেইন্ট অপ্টিমাইজ করুন যেন তা unnecessary লকিং বা ব্যাকআপ অপারেশন সৃষ্টি না করে।

    ALTER TABLE Employees ADD CONSTRAINT PK_EmployeeID PRIMARY KEY (EmployeeID);
    

৭. স্টোরড প্রোসিডিউরের মধ্যে লকিং অপ্টিমাইজেশন

লকিং সমস্যা পারফরম্যান্সের উপর নেতিবাচক প্রভাব ফেলতে পারে, বিশেষ করে বড় ট্রানজেকশনের ক্ষেত্রে। ডেডলক (deadlock) এড়ানো এবং লক টাইমিং উন্নত করা অত্যন্ত গুরুত্বপূর্ণ।

টিপ:

  • LOCK অপশন ব্যবহার করে লক টাইপ কনফিগার করুন:

    LOCK TABLE Employees IN EXCLUSIVE MODE;
    
  • Isolation Levels সেট করুন যাতে ম্যানুয়ালি কন্ট্রোল করা যায় ডেটাবেসের লকিং আচরণ।

    SET CURRENT ISOLATION = CS;
    

৮. পর্যবেক্ষণ এবং ডিবাগিং

Stored Procedures এর পারফরম্যান্স ট্র্যাক করতে আপনাকে পর্যবেক্ষণ এবং ডিবাগিং সরঞ্জাম ব্যবহার করতে হবে।

টিপ:

  • DB2 Explain এবং db2pd টুল ব্যবহার করে Stored Procedure এর কার্যকারিতা এবং পারফরম্যান্স বিশ্লেষণ করুন:

    db2pd -db <dbname> -stored_procs
    
  • EXPLAIN PLAN কমান্ডের মাধ্যমে কুয়েরি পরিকল্পনা পর্যবেক্ষণ করুন:

    EXPLAIN PLAN FOR
    SELECT * FROM EmployeeData.Employees WHERE Salary > 50000;
    

সারসংক্ষেপ

DB2-এ Stored Procedures পারফরম্যান্স অপ্টিমাইজেশন হল ডেটাবেসের কার্যকারিতা এবং দক্ষতা বৃদ্ধির একটি গুরুত্বপূর্ণ প্রক্রিয়া। সঠিকভাবে ট্রানজেকশন ম্যানেজমেন্ট, কুয়েরি অপ্টিমাইজেশন, ডেটাবেস কনফিগারেশন, লকিং অপ্টিমাইজেশন, এবং ইনডেক্সিং প্রয়োগ করলে Stored Procedures এর পারফরম্যান্স উল্লেখযোগ্যভাবে বৃদ্ধি পায়। DB2-এ Stored Procedures এর কার্যকারিতা পর্যবেক্ষণ ও অপ্টিমাইজেশন ডেটাবেস ম্যানেজমেন্টের জন্য অত্যন্ত গুরুত্বপূর্ণ এবং কার্যকরী।

common.content_added_by
টপ রেটেড অ্যাপ

স্যাট অ্যাকাডেমী অ্যাপ

আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।

ভিডিও
লাইভ ক্লাস
এক্সাম
ডাউনলোড করুন
Promotion