Database Tutorials SQL এ Triggers এবং Events গাইড ও নোট

430

Triggers এবং Events SQL এর গুরুত্বপূর্ণ বৈশিষ্ট্য যা ডেটাবেসের স্বয়ংক্রিয় কার্যাবলী এবং নির্দিষ্ট সময়ে ক্রিয়াকলাপ সম্পাদন করার জন্য ব্যবহৃত হয়। এগুলি বিশেষ পরিস্থিতিতে ডেটাবেসে কার্যক্রমের উপর নজর রাখে এবং নির্দিষ্ট শর্ত পূর্ণ হলে স্বয়ংক্রিয়ভাবে নির্ধারিত কাজ সম্পাদন করে।


1. Triggers (ট্রিগার)

Triggers হল স্বয়ংক্রিয়ভাবে চলতে থাকা SQL কোড যা ডেটাবেসের ওপর কোনো নির্দিষ্ট পরিবর্তন (যেমন: INSERT, UPDATE, DELETE) ঘটলে ট্রিগার হয়ে কার্যকর হয়। ট্রিগার সাধারণত ডেটাবেসে ডেটা পরিবর্তন হওয়া আগেই বা পরে কিছু নির্দিষ্ট কাজ সম্পাদন করতে ব্যবহৃত হয়।

Trigger এর ব্যবহার:

  • ডেটাবেসের ডাটা সঠিকতা নিশ্চিত করা
  • লগিং বা অডিট ট্রেইল তৈরি করা
  • ডেটা ইনসার্ট, আপডেট, বা ডিলিট হওয়ার পর বিভিন্ন কার্যকলাপ সম্পাদন করা

Trigger এর সিনট্যাক্স:

CREATE TRIGGER trigger_name
{BEFORE | AFTER} {INSERT | UPDATE | DELETE}
ON table_name
FOR EACH ROW
BEGIN
   -- trigger action
END;
  • trigger_name: ট্রিগারের নাম
  • BEFORE | AFTER: এই ক্লজটি নির্ধারণ করে ট্রিগারটি ডেটাবেস পরিবর্তনের আগে (BEFORE) বা পরে (AFTER) চলবে।
  • INSERT | UPDATE | DELETE: এই অপশনগুলির মাধ্যমে আপনি নির্ধারণ করেন যে, কোন ধরনের পরিবর্তন (যেমন ইনসার্ট, আপডেট, বা ডিলিট) ঘটলে ট্রিগারটি সক্রিয় হবে।

উদাহরণ:

ধরা যাক, আমাদের একটি sales টেবিল আছে এবং আমরা চাইলে যদি কোনো নতুন sale ইনসার্ট করা হয়, তবে audit_log টেবিলে লগ ইনসার্ট হবে:

CREATE TRIGGER log_sale_insert
AFTER INSERT
ON sales
FOR EACH ROW
BEGIN
   INSERT INTO audit_log (action, action_time)
   VALUES ('INSERT', NOW());
END;

এই ট্রিগারটি sales টেবিলে কোনো নতুন রেকর্ড ইনসার্ট হওয়ার পরে audit_log টেবিলে একটি নতুন রেকর্ড ইনসার্ট করবে।


2. Events (ইভেন্টস)

Events হল একটি টাইম-বেসড SQL ফিচার যা নির্দিষ্ট সময়ে বা নির্দিষ্ট ইন্টারভেলে একটি নির্ধারিত কুয়েরি বা কাজ চালাতে ব্যবহৃত হয়। SQL Event Scheduler ডেটাবেসে এই ধরনের কাজ পরিচালনা করে।

Event এর ব্যবহার:

  • নির্দিষ্ট সময়ে ডেটাবেসের কিছু কার্যকলাপ সম্পাদন করা
  • রেগুলার ব্যাকআপ গ্রহণ করা
  • ডেটাবেসের কিছু কাজ স্বয়ংক্রিয়ভাবে সম্পন্ন করা

Event এর সিনট্যাক্স:

CREATE EVENT event_name
ON SCHEDULE EVERY interval
DO
   -- event action;
  • event_name: ইভেন্টের নাম
  • ON SCHEDULE EVERY interval: এই অংশে ইভেন্টটি কতটা সময় পর পর চলবে তা নির্ধারণ করা হয় (যেমন: EVERY 1 DAY, EVERY 1 HOUR)।
  • DO: ইভেন্ট চললে কী কাজ করবে তা উল্লেখ করা হয়।

উদাহরণ:

ধরা যাক, আমরা চাই প্রতিদিন রাতে logs টেবিলের পুরনো ডেটা মুছে ফেলতে:

CREATE EVENT delete_old_logs
ON SCHEDULE EVERY 1 DAY
STARTS '2024-12-01 00:00:00'
DO
   DELETE FROM logs WHERE log_date < CURDATE() - INTERVAL 30 DAY;

এই ইভেন্টটি প্রতিদিন রাত ১২টায় logs টেবিলের ৩০ দিন পুরনো ডেটা মুছে ফেলবে।


Triggers এবং Events এর মধ্যে পার্থক্য

  • Triggers হল ডেটাবেস অপারেশনের সাথে সংযুক্ত (যেমন, ইনসার্ট, আপডেট বা ডিলিটের পরে) এবং স্বয়ংক্রিয়ভাবে ক্রিয়াকলাপ সম্পাদন করে।
  • Events হল সময়ভিত্তিক বা সময়সীমার মধ্যে নির্ধারিত কাজ সম্পাদন করে এবং এগুলি নির্দিষ্ট সময় বা ইন্টারভ্যালের জন্য চালানো হয়।

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

Content added By

Triggers কী এবং কিভাবে কাজ করে?

419

Triggers হল স্বয়ংক্রিয় SQL কোড যা কোনো নির্দিষ্ট ডেটাবেস ইভেন্ট (যেমন INSERT, UPDATE, DELETE) ঘটলে চলতে শুরু করে। এটি একটি বিশেষ ধরনের স্টোরড প্রোসিডিউর যা ডেটাবেসে কোন পরিবর্তন ঘটানোর আগে বা পরে স্বয়ংক্রিয়ভাবে রান হয়। ট্রিগার মূলত ডেটাবেসের ইন্টিগ্রিটি বজায় রাখতে এবং নির্দিষ্ট কাজ বা যাচাই করার জন্য ব্যবহার করা হয়।


Triggers এর কাজ কী?

Triggers এর কাজ হল ডেটাবেসের উপর নির্দিষ্ট ইভেন্ট ঘটলে তা স্বয়ংক্রিয়ভাবে কিছু এক্সিকিউট করা। উদাহরণস্বরূপ:

  • ডেটা ইনসার্ট করার আগে বা পরে কিছু চেক বা অ্যাকশন নেওয়া
  • ডেটা আপডেট করার আগে বা পরে কিছু যাচাই বা রেকর্ড পরিবর্তন করা
  • ডেটা ডিলিট করার আগে বা পরে একটি লজিকাল যাচাই বা রেকর্ড মুছে ফেলা

Triggers মূলত ডেটাবেসের ইন্টিগ্রিটি রক্ষা করে এবং প্রোগ্রামিংয়ে স্বয়ংক্রিয়তা বা অটোমেশন আনতে সহায়তা করে।


Triggers এর টাইপস

  1. BEFORE Trigger
    এই ধরনের ট্রিগার একটি নির্দিষ্ট টেবিলে ডেটা ইনসার্ট, আপডেট বা ডিলিট করার আগে চালিত হয়। এর মাধ্যমে আপনি ডেটাবেসে পরিবর্তন আনার আগে কিছু যাচাই বা প্রক্রিয়া সম্পন্ন করতে পারেন।

    উদাহরণ: BEFORE INSERT Trigger

    CREATE TRIGGER before_insert_employee
    BEFORE INSERT ON employees
    FOR EACH ROW
    BEGIN
        IF NEW.salary < 5000 THEN
            SET NEW.salary = 5000;
        END IF;
    END;
    

    উপরের উদাহরণে, BEFORE INSERT Trigger একটি চেক করবে যে, যদি স্যালারি ৫০০০ এর কম হয়, তাহলে এটি অটোমেটিক্যালি ৫০০০ সেট করে দেবে।

  2. AFTER Trigger
    এই ধরনের ট্রিগার একটি নির্দিষ্ট টেবিলে ডেটা ইনসার্ট, আপডেট বা ডিলিট করার পর চালিত হয়। এটি সাধারণত সেইসব কাজের জন্য ব্যবহার করা হয় যেগুলি ডেটা আপডেট হওয়ার পর করা উচিত।

    উদাহরণ: AFTER UPDATE Trigger

    CREATE TRIGGER after_update_employee
    AFTER UPDATE ON employees
    FOR EACH ROW
    BEGIN
        IF OLD.salary <> NEW.salary THEN
            INSERT INTO salary_changes (employee_id, old_salary, new_salary)
            VALUES (NEW.employee_id, OLD.salary, NEW.salary);
        END IF;
    END;
    

    এই উদাহরণে, AFTER UPDATE Trigger ডেটাবেসে একটি স্যালারি আপডেট হলে, সেই পরিবর্তনটি একটি আলাদা টেবিলে সেভ করে রাখে।

  3. INSTEAD OF Trigger
    এই ধরনের ট্রিগার নির্দিষ্ট ইভেন্টের পরিবর্তে একটি নির্দিষ্ট কাজ করে। এটি সাধারণত VIEW এর ক্ষেত্রে ব্যবহার করা হয়, যেখানে ডেটাবেসের মূল টেবিল পরিবর্তন করার পরিবর্তে একটি নির্দিষ্ট কাস্টমাইজড কার্যকলাপ করা হয়।

    উদাহরণ: INSTEAD OF DELETE Trigger

    CREATE TRIGGER instead_of_delete_employee
    INSTEAD OF DELETE ON employees
    FOR EACH ROW
    BEGIN
        INSERT INTO deleted_employees (employee_id, name, reason)
        VALUES (OLD.employee_id, OLD.name, 'Deleted due to business reasons');
    END;
    

    এখানে, INSTEAD OF DELETE Trigger যখন কোনো কর্মচারী ডিলিট করা হবে, তখন মূল টেবিল থেকে ডিলিট না হয়ে বরং সেই কর্মচারীর তথ্য একটি আলাদা টেবিলে সংরক্ষণ করা হবে।


Triggers কিভাবে কাজ করে?

  1. Trigger ইভেন্ট: প্রথমে, একটি ট্রিগার সংশ্লিষ্ট টেবিলের ওপর কোনো ইভেন্ট (INSERT, UPDATE, DELETE) ঘটে।
  2. Trigger Activation: ইভেন্ট ঘটলে, সংশ্লিষ্ট ট্রিগারটি একটিভেট হয় এবং নির্ধারিত কার্যক্রম (যেমন: ডেটা পরিবর্তন, লগিং, যাচাই ইত্যাদি) সম্পাদন করা হয়।
  3. Trigger Execution: ট্রিগারটি একবার চালু হলে, এটি কোডের মাধ্যমে নির্ধারিত কার্যক্রম সম্পন্ন করে। এটি BEFORE বা AFTER ইভেন্টের উপর নির্ভর করে।
  4. Transaction Completion: যদি ট্রিগার কোনো ভুল বা লজিক্যাল চেক চিহ্নিত করে, তবে সেটি পুরো ট্রানজ্যাকশনকে রদ করতে পারে বা সংশোধিত ফলাফল ডেটাবেসে সংরক্ষণ করতে পারে।

Triggers এর সুবিধা এবং অসুবিধা

সুবিধা:

  • স্বয়ংক্রিয়তা: ট্রিগারগুলি ডেটাবেসের বিভিন্ন কার্যক্রম অটোমেটিক্যালি পরিচালনা করে, ফলে অ্যাপ্লিকেশন ডেভেলপারের জন্য কাজ সহজ হয়।
  • ডেটাবেস ইন্টিগ্রিটি বজায় রাখা: এটি ডেটাবেসের মধ্যে নির্দিষ্ট নিয়ম এবং শর্ত বজায় রাখে, যেমন ডেটা যাচাই, অটোমেটিক ক্যাশিং ইত্যাদি।
  • লগিং এবং অডিটিং: ট্রিগার ব্যবহার করে আপনি ডেটাবেসে সকল পরিবর্তন লগ বা ট্র্যাক করতে পারেন, যা পরবর্তী সময়ে অডিটিং এর জন্য সহায়ক।

অসুবিধা:

  • পারফরম্যান্স ইস্যু: ট্রিগারগুলি অতিরিক্ত কার্যক্রম চালাতে পারে, যা ডেটাবেসের পারফরম্যান্সে নেতিবাচক প্রভাব ফেলতে পারে।
  • ডিবাগিং এর জটিলতা: কিছু ক্ষেত্রে, ট্রিগারের কার্যক্রম প্রোগ্রামিং বা কুয়েরি ডিবাগিংকে জটিল করে তুলতে পারে।
  • ডিপেন্ডেন্সি: অতিরিক্ত ট্রিগার ব্যবহারে ডেটাবেসের উপর নির্ভরশীলতা বেড়ে যেতে পারে এবং কোনো পরিবর্তন করলে সেটা পুরো সিস্টেমের ওপর প্রভাব ফেলতে পারে।

উপসংহার

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

Content added By

BEFORE এবং AFTER Triggers তৈরি

293

Triggers হল বিশেষ ধরনের স্টোরড প্রোগ্রাম যা ডেটাবেসে একটি নির্দিষ্ট কার্যকলাপ (যেমন: INSERT, UPDATE, DELETE) ঘটে এমন কোনো ঘটনাকে সাড়া দিয়ে কার্যকর হয়। SQL ট্রিগার মূলত ডেটাবেসে অটোমেটিক্যালি কিছু কাজ করার জন্য ব্যবহৃত হয়, যেমন, ডেটা প্রক্রিয়াকরণের আগে বা পরে কিছু অতিরিক্ত কাজ সম্পন্ন করা।

BEFORE এবং AFTER ট্রিগার দুটি প্রধান ধরনের ট্রিগার, যা ডেটাবেসের কোনো অপারেশন সম্পন্ন হওয়ার আগে বা পরে চালিত হয়।

  • BEFORE Trigger: ডেটাবেসে কোন পরিবর্তন (INSERT, UPDATE, DELETE) ঘটানোর আগে এটি কার্যকর হয়।
  • AFTER Trigger: ডেটাবেসে কোন পরিবর্তন (INSERT, UPDATE, DELETE) ঘটানোর পরে এটি কার্যকর হয়।

নিচে BEFORE এবং AFTER ট্রিগার তৈরির সঠিক পদ্ধতি দেখানো হল:


১. BEFORE Trigger তৈরি

BEFORE Trigger ব্যবহার করা হয় যখন আমরা কোনো ডেটা ইনসার্ট, আপডেট বা ডিলিট করার আগে কিছু অতিরিক্ত কাজ সম্পন্ন করতে চাই। উদাহরণস্বরূপ, একটি salary কলামের মান UPDATE করার আগে নিশ্চিত করতে হবে যে তার নতুন মান একটি নির্দিষ্ট সীমার মধ্যে আছে কিনা।

Syntax:

CREATE TRIGGER trigger_name
BEFORE INSERT | UPDATE | DELETE
ON table_name
FOR EACH ROW
BEGIN
   -- Trigger body
END;

উদাহরণ:

ধরা যাক, আমরা একটি BEFORE INSERT ট্রিগার তৈরি করতে চাই যা নিশ্চিত করবে যে কোনো নতুন কর্মচারীর salary 1000-এর কম হবে না।

CREATE TRIGGER before_insert_employee
BEFORE INSERT
ON employees
FOR EACH ROW
BEGIN
    IF NEW.salary < 1000 THEN
        SET NEW.salary = 1000; -- Salary will be set to 1000 if it is less than 1000
    END IF;
END;

এখানে:

  • NEW.salary: এখানে NEW শব্দটি বর্তমান রেকর্ডের মানের প্রতিনিধিত্ব করে, কারণ এটি ইনসার্ট বা আপডেট করা হচ্ছে।
  • BEFORE INSERT: এটি নির্দেশ করে যে INSERT অপারেশনের আগে ট্রিগারটি কার্যকর হবে।

২. AFTER Trigger তৈরি

AFTER Trigger ব্যবহৃত হয় যখন কোনো ডেটা ইনসার্ট, আপডেট বা ডিলিট করার পরে অতিরিক্ত কোনো কার্যকলাপ সম্পাদন করতে হয়। এটি সাধারণত লগিং, অডিট ট্রেইল তৈরি, বা ডেটাবেসে অন্য টেবিল আপডেট করার জন্য ব্যবহৃত হয়।

Syntax:

CREATE TRIGGER trigger_name
AFTER INSERT | UPDATE | DELETE
ON table_name
FOR EACH ROW
BEGIN
   -- Trigger body
END;

উদাহরণ:

ধরা যাক, আমরা একটি AFTER UPDATE ট্রিগার তৈরি করতে চাই যা প্রতিটি আপডেটের পরে একটি log টেবিলকে আপডেট করবে, যাতে ওই কর্মচারীর salary পরিবর্তন হওয়ার রেকর্ড রাখা যায়।

CREATE TRIGGER after_update_salary
AFTER UPDATE
ON employees
FOR EACH ROW
BEGIN
    INSERT INTO salary_change_log (employee_id, old_salary, new_salary, change_date)
    VALUES (NEW.employee_id, OLD.salary, NEW.salary, NOW());
END;

এখানে:

  • NEW.salary: আপডেটের পর নতুন মান।
  • OLD.salary: আপডেটের আগের পুরনো মান।
  • NOW(): বর্তমান সময় বা তারিখ, যেটি change_date কলামে সন্নিবেশিত হবে।

BEFORE vs AFTER Trigger

AspectBEFORE TriggerAFTER Trigger
Execution Timeডেটাবেস অপারেশন (INSERT, UPDATE, DELETE) আগেডেটাবেস অপারেশন (INSERT, UPDATE, DELETE) পর
Use Caseডেটাবেস অপারেশনটি কার্যকর হওয়ার আগে পরিবর্তন বা যাচাই করা।ডেটাবেস অপারেশনটি সফলভাবে সম্পন্ন হওয়ার পর কোনো প্রক্রিয়া চালানো।
Exampleসঠিক ডেটা ইনসার্ট বা আপডেট নিশ্চিত করা (যেমন: ভ্যালিডেশন)।লগ তৈরি বা পরবর্তী পদক্ষেপ গ্রহণ (যেমন: অ্যাকাউন্টিং বা অডিট)।

Triggers ব্যবহার করার কিছু চ্যালেঞ্জ

  1. পারফরম্যান্স প্রভাব: ট্রিগার ব্যবহারের ফলে ডেটাবেসের কার্যক্ষমতা কিছুটা কমে যেতে পারে, বিশেষ করে যদি ট্রিগারগুলি জটিল বা বারবার কার্যকর হয়।
  2. ডিবাগিং: ট্রিগারগুলির ডিবাগ করা অনেক কঠিন হতে পারে, কারণ এগুলি ব্যাকগ্রাউন্ডে অটোমেটিকভাবে চলে।
  3. অপ্রত্যাশিত ফলাফল: ভুল ট্রিগার লজিক বা ইচ্ছামত ট্রিগার ব্যবহারে অপ্রত্যাশিত ডেটাবেস পরিবর্তন ঘটতে পারে।

উপসংহার:

BEFORE এবং AFTER ট্রিগার দুটি SQL ডেটাবেসের মধ্যে বিভিন্ন রকম অটোমেটিক কার্যকলাপ পরিচালনার জন্য ব্যবহৃত হয়। এটি ডেটাবেস ম্যানেজমেন্ট এবং প্রোগ্রামিংয়ে অত্যন্ত শক্তিশালী এবং কার্যকরী টুল, তবে এর সঠিক ব্যবহার ডেটাবেস পারফরম্যান্স ও নিরাপত্তা নিশ্চিত করার জন্য গুরুত্বপূর্ণ।

Content added By

Complex Trigger Operations

250

Triggers SQL এর একটি শক্তিশালী ফিচার যা স্বয়ংক্রিয়ভাবে কিছু ক্রিয়া বা অপারেশন সম্পাদন করতে ব্যবহৃত হয় যখন কোনো নির্দিষ্ট ঘটনা (event) ঘটে। যেমন: একটি টেবিলের ডেটা পরিবর্তিত হলে (INSERT, UPDATE, DELETE) নির্দিষ্ট একটি অ্যাকশন বা কাস্টম কিউরি চালানো।

Complex Trigger Operations হল এমন ট্রিগার যা একাধিক অপারেশন বা লজিক্যাল কন্ডিশন প্রয়োগ করে, এবং এটি সাধারণত বিভিন্ন টেবিলের মধ্যে সমন্বয় সাধন করতে ব্যবহৃত হয়। Complex Trigger গুলি সাধারণত ব্যবসায়িক লজিক এবং ডেটাবেসের একাধিক টেবিলের মধ্যে সম্পর্ক স্থাপনের জন্য গুরুত্বপূর্ণ।


Trigger Types (Trigger এর ধরণ)

  1. BEFORE Trigger: এই ট্রিগারটি ইনসার্ট, আপডেট অথবা ডিলিট অপারেশন সম্পাদন করার আগে কার্যকর হয়। এটি ডেটাবেসে পরিবর্তন করার আগে শর্ত যাচাই করতে সহায়তা করে।
  2. AFTER Trigger: এই ট্রিগারটি ইনসার্ট, আপডেট অথবা ডিলিট অপারেশন সম্পাদন করার পরে কার্যকর হয়। এটি মূলত ডেটাবেসে পরিবর্তন সম্পন্ন হওয়ার পরে অতিরিক্ত ক্রিয়াকলাপ বা যাচাই করতে ব্যবহৃত হয়।
  3. INSTEAD OF Trigger: এই ধরনের ট্রিগারটি সাধারণত VIEW তে ব্যবহৃত হয় এবং এটি কোনও পরিবর্তন বা ক্রিয়ার পরিবর্তে নিজেই কোনো অপারেশন সম্পাদন করে। উদাহরণস্বরূপ, INSTEAD OF INSERT ট্রিগারটি কাস্টম ইনসার্ট অপারেশন পরিচালনা করতে পারে।

Complex Trigger Operations এর উদাহরণ

ধরা যাক, আমাদের দুটি টেবিল আছে:

  • orders (অর্ডারের তথ্য)
  • inventory (পণ্য স্টক সম্পর্কিত তথ্য)

আমরা একটি BEFORE INSERT ট্রিগার তৈরি করতে চাই, যা নিশ্চিত করবে যে পণ্যের স্টক পর্যাপ্ত আছে কিনা, অর্ডার দেওয়ার পূর্বে।

উদাহরণ: BEFORE INSERT Trigger - স্টক চেক

CREATE TRIGGER check_inventory_before_order
BEFORE INSERT ON orders
FOR EACH ROW
BEGIN
    DECLARE stock_count INT;
    
    -- স্টকের পরিমাণ খুঁজে বের করুন
    SELECT stock INTO stock_count
    FROM inventory
    WHERE product_id = NEW.product_id;

    -- যদি স্টক পর্যাপ্ত না হয়, তাহলে অ্যাকশন রিভার্ট করুন
    IF stock_count < NEW.quantity THEN
        SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Insufficient stock for this order';
    END IF;
END;

এই ট্রিগারটি:

  • Before Insert অপারেশন চালানোর পূর্বে কার্যকর হবে।
  • inventory টেবিল থেকে নির্দিষ্ট পণ্যের স্টক চেক করবে।
  • যদি স্টক পর্যাপ্ত না হয়, তাহলে অর্ডার গ্রহণ করবে না এবং একটি কাস্টম ত্রুটি (Error) সিগন্যাল পাঠাবে।

UPDATE Trigger Example: Tracking Changes Across Tables

ধরা যাক, আমাদের একটি employees টেবিল রয়েছে এবং আমরা চাই যে, কোনো কর্মীর বেতন পরিবর্তন হলে সেই পরিবর্তনকে একটি salary_history টেবিলে রেকর্ড করা হোক।

উদাহরণ: AFTER UPDATE Trigger - বেতন ইতিহাস রেকর্ড

CREATE TRIGGER log_salary_change
AFTER UPDATE ON employees
FOR EACH ROW
BEGIN
    -- শুধুমাত্র বেতন পরিবর্তন হলে রেকর্ড করা হবে
    IF OLD.salary != NEW.salary THEN
        INSERT INTO salary_history (employee_id, old_salary, new_salary, change_date)
        VALUES (NEW.employee_id, OLD.salary, NEW.salary, NOW());
    END IF;
END;

এই ট্রিগারটি:

  • After Update অপারেশন পর সম্পাদিত হবে।
  • employees টেবিলের বেতন পরিবর্তন হলেই, সেটি salary_history টেবিলে লগ হিসেবে রেকর্ড করবে।

Complex Operations in Triggers

Complex trigger operations সাধারণত একাধিক টেবিলের মধ্যে সম্পর্ক তৈরি করতে ব্যবহৃত হয়। যেমন:

  • Nested Queries: ট্রিগারে নেস্টেড কিউরি ব্যবহার করা যেতে পারে যাতে একাধিক টেবিল থেকে তথ্য যাচাই করা হয়।
  • Multiple Table Updates: একটি ট্রিগার একাধিক টেবিল আপডেট করতে পারে, যেমন AFTER INSERT বা AFTER UPDATE ট্রিগার এর মাধ্যমে এক টেবিলের পরিবর্তন অন্য টেবিলের ডেটাকে প্রভাবিত করতে পারে।
  • Transaction Control: ট্রিগার এর মধ্যে COMMIT বা ROLLBACK ব্যবহার করে ডেটাবেসের ট্রানজেকশন কন্ট্রোল করা যায়। এতে নিশ্চিত করা যায় যে, একাধিক আপডেট অপারেশন একসাথে সফল হয়েছে।

Complex Trigger Examples

Example 1: Cascading Delete Trigger

ধরা যাক, orders এবং order_items টেবিল রয়েছে এবং আপনি চান যে, যদি একটি অর্ডার orders টেবিল থেকে মুছে ফেলা হয়, তবে সেই অর্ডারের আইটেমগুলোও order_items টেবিল থেকে স্বয়ংক্রিয়ভাবে মুছে যাক।

CREATE TRIGGER delete_order_items
AFTER DELETE ON orders
FOR EACH ROW
BEGIN
    DELETE FROM order_items WHERE order_id = OLD.order_id;
END;

এই ট্রিগারটি:

  • After Delete ঘটলে কার্যকর হবে।
  • orders টেবিল থেকে কোনো অর্ডার মুছে ফেলা হলে তার সাথে সম্পর্কিত আইটেমগুলো order_items টেবিল থেকেও মুছে ফেলা হবে।

Example 2: Maintaining Aggregate Data

ধরা যাক, আপনি চান যে, যখন নতুন অর্ডার orders টেবিলে যোগ হবে, তখন সেই অর্ডারের মোট পরিমাণ (total_amount) customer_stats টেবিলে আপডেট হবে।

CREATE TRIGGER update_customer_total
AFTER INSERT ON orders
FOR EACH ROW
BEGIN
    UPDATE customer_stats
    SET total_spent = total_spent + NEW.amount
    WHERE customer_id = NEW.customer_id;
END;

এই ট্রিগারটি:

  • After Insert অপারেশন সম্পন্ন হওয়ার পরে customer_stats টেবিলের total_spent আপডেট করবে।

উপসংহার

Complex Trigger Operations SQL ডেটাবেসের শক্তিশালী ফিচার যা বিভিন্ন টেবিলের মধ্যে সম্পর্ক স্থাপন করে এবং ডেটা ইন্টেগ্রিটি নিশ্চিত করতে সাহায্য করে। এটি ট্রানজেকশন ম্যানেজমেন্ট, ডেটা অডিটিং, এবং ব্যবসায়িক নিয়মাবলী কার্যকর করতে গুরুত্বপূর্ণ ভূমিকা পালন করে। তবে, ট্রিগার ব্যবহারের সময় সঠিক কনফিগারেশন এবং পরীক্ষা করা গুরুত্বপূর্ণ, কারণ এটি ডেটাবেসের কর্মক্ষমতা এবং স্কেলেবিলিটি প্রভাবিত করতে পারে।

Content added By

Triggers এবং Stored Procedure এর মধ্যে পার্থক্য

299

Triggers এবং Stored Procedures SQL এর গুরুত্বপূর্ণ বৈশিষ্ট্য, কিন্তু তাদের কাজ এবং ব্যবহারের উদ্দেশ্য আলাদা। নিচে এই দুটি কনসেপ্টের মধ্যে প্রধান পার্থক্য তুলে ধরা হল:


১. Triggers:

Trigger হলো একটি বিশেষ ধরনের SQL প্রোগ্রাম যা কোনো নির্দিষ্ট ইভেন্ট (যেমন, INSERT, UPDATE, বা DELETE) ঘটলে স্বয়ংক্রিয়ভাবে কার্যকর হয়। এটি ডেটাবেসে কোনো পরিবর্তন ঘটানোর আগে বা পরে কিছু কার্যক্রম সম্পাদন করতে ব্যবহৃত হয়। Trigger সাধারণত ডেটাবেস ইভেন্ট দ্বারা ট্রিগার হয় এবং সেগুলি স্বয়ংক্রিয়ভাবে চলতে থাকে, অর্থাৎ ব্যবহারকারী বা অ্যাপ্লিকেশন দ্বারা সরাসরি চালানো হয় না।

Triggers এর বৈশিষ্ট্য:

  • স্বয়ংক্রিয় কার্যকলাপ: Trigger স্বয়ংক্রিয়ভাবে একটি ইভেন্টের পরে অথবা আগে চলে (যেমন AFTER INSERT, BEFORE DELETE)।
  • ডেটাবেস স্তরে কাজ করে: Trigger শুধুমাত্র ডেটাবেসের মধ্যে ঘটে এমন কার্যকলাপের জন্য ব্যবহৃত হয় এবং সাধারণত টেবিল বা ভিউয়ের ওপর নির্দিষ্ট হয়।
  • নির্দিষ্ট ইভেন্টের উপর নির্ভরশীল: Trigger গুলি বিশেষ একটি ইভেন্ট (যেমন: INSERT, UPDATE, DELETE) সম্পাদন করার সময় কার্যকর হয়।

Trigger উদাহরণ:

ধরা যাক, আমরা employees টেবিলে একটি Trigger তৈরি করতে চাই যাতে একটি নতুন কর্মচারী যুক্ত করার পরে একটি লগ টেবিলের মধ্যে তথ্য ঢোকানো হয়:

CREATE TRIGGER after_employee_insert
AFTER INSERT ON employees
FOR EACH ROW
BEGIN
   INSERT INTO employee_log (employee_id, action, action_time)
   VALUES (NEW.employee_id, 'INSERT', NOW());
END;

এখানে:

  • AFTER INSERT: employees টেবিলে কোনো নতুন রেকর্ড যোগ হলে Trigger টি কার্যকর হবে।
  • NEW.employee_id: নতুন রেকর্ডের employee_id কলামটি নেওয়া হবে।

২. Stored Procedure:

Stored Procedure একটি প্রি-কম্পাইল্ড SQL প্রোগ্রাম বা কোডের সঙ্কলন যা একাধিক SQL স্টেটমেন্ট বা কার্যকলাপ একত্রে সম্পাদন করতে ব্যবহৃত হয়। একটি Stored Procedure বিভিন্ন কাজের জন্য তৈরি করা যেতে পারে, যেমন ডেটাবেসে ডেটা আপডেট, ইনসার্ট বা সিলেক্ট করা। এটি ডেটাবেসে সংরক্ষিত থাকে এবং যেকোনো সময় প্রয়োজনে চালানো যেতে পারে।

Stored Procedure এর বৈশিষ্ট্য:

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

Stored Procedure উদাহরণ:

ধরা যাক, আমাদের একটি Stored Procedure তৈরি করতে চাই, যা নির্দিষ্ট department_id অনুযায়ী কর্মচারীদের তথ্য বের করবে:

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

এখানে:

  • dept_id হল ইনপুট প্যারামিটার, যা স্টোরড প্রোসিডিউরটিকে কোনো নির্দিষ্ট বিভাগ অনুযায়ী কর্মচারীদের তথ্য নিয়ে আসতে সহায়তা করে।

Triggers এবং Stored Procedure এর মধ্যে পার্থক্য:

বিশেষত্বTriggerStored Procedure
কার্যকর হওয়াডেটাবেসে নির্দিষ্ট ইভেন্টের উপর নির্ভরশীল (যেমন INSERT, UPDATE, DELETE)নির্দিষ্টভাবে কল বা চালানোর মাধ্যমে কার্যকর হয়
স্বয়ংক্রিয়তাস্বয়ংক্রিয়ভাবে কার্যকর হয় যখন ইভেন্ট ঘটেম্যানুয়ালি কল করতে হয় বা নির্দিষ্ট সময়ের মধ্যে চলানো হয়
প্যারামিটারসাধারণত প্যারামিটার নেওয়ার ক্ষমতা নেইইনপুট এবং আউটপুট প্যারামিটার থাকতে পারে
ব্যবহারডেটাবেসের নির্দিষ্ট ইভেন্টে স্বয়ংক্রিয়ভাবে কিছু করতেএকাধিক SQL স্টেটমেন্ট একত্রে সম্পাদন করার জন্য ব্যবহৃত হয়
প্রক্রিয়াইভেন্টের পরে বা আগে কিছু কাজ করার জন্য ব্যবহৃতকমপ্লেক্স টাস্ক, একাধিক স্টেটমেন্ট চালানোর জন্য ব্যবহৃত
প্রয়োজনীয়তাপ্রোগ্রাম চালানোর জন্য কোন ম্যানুয়াল ইনপুটের প্রয়োজন নেইম্যানুয়ালি স্টোরড প্রোসিডিউর কল করতে হয়

উপসংহার:

  • Triggers ব্যবহার করা হয় যখন ডেটাবেসে একটি নির্দিষ্ট ইভেন্ট ঘটে এবং এর সাথে কিছু অটোমেটিক কাজ করতে হয় (যেমন, একটি রেকর্ড ইনসার্ট করার পরে লগিং করা)।
  • Stored Procedures ব্যবহার করা হয় যখন আপনি একাধিক SQL কুইরি বা কার্যক্রম একসাথে চালাতে চান, এবং এগুলো ম্যানুয়ালি কল করতে হয়।

প্রত্যেকটি তাদের নিজ নিজ উদ্দেশ্য পূরণের জন্য উপযুক্ত এবং ব্যবহৃত হয়।

Content added By
Promotion

Are you sure to start over?

Loading...