Database Tutorials SQLite এর Transactions এবং ACID Properties গাইড ও নোট

435

Transactions এবং ACID Properties হলো ডাটাবেস সিস্টেমে ডাটা নিরাপত্তা এবং বিশ্বস্ততা নিশ্চিত করার জন্য গুরুত্বপূর্ণ ধারণা। SQLite, যেমন অন্যান্য রিলেশনাল ডাটাবেস সিস্টেম, ACID (Atomicity, Consistency, Isolation, Durability) প্রিন্সিপল অনুসরণ করে, যার মাধ্যমে ডাটাবেস অপারেশনগুলি নিশ্চিতভাবে এবং বিশ্বস্তভাবে সম্পাদিত হয়।


Transactions

Transaction হল এক বা একাধিক SQL অপারেশনের একটি গ্রুপ যা একসাথে কার্যকর হতে হয়। একটি ট্রানজেকশন তখনই সফল হয় যখন তার সব অপারেশন সঠিকভাবে সম্পন্ন হয়; যদি কোনো একটি অপারেশন ব্যর্থ হয়, তবে পুরো ট্রানজেকশনটি বাতিল হয়ে যায় এবং ডাটাবেস আগের অবস্থায় ফিরে যায়।

SQLite-এ, আপনি BEGIN TRANSACTION, COMMIT, এবং ROLLBACK কমান্ড ব্যবহার করে ট্রানজেকশন শুরু, শেষ এবং বাতিল করতে পারেন।

ট্রানজেকশন শুরু করা

BEGIN TRANSACTION;

এটি একটি নতুন ট্রানজেকশন শুরু করে।

ট্রানজেকশন শেষ করা (COMMIT)

COMMIT;

এই কমান্ডটি সমস্ত পরিবর্তন সেভ করে ডাটাবেসে স্থায়ীভাবে সংরক্ষণ করে এবং ট্রানজেকশন বন্ধ করে।

ট্রানজেকশন বাতিল করা (ROLLBACK)

ROLLBACK;

এই কমান্ডটি ট্রানজেকশনটি বাতিল করে এবং সমস্ত পরিবর্তন ফিরিয়ে নিয়ে ডাটাবেস পূর্বাবস্থায় ফিরে আসে।


ACID Properties

SQLite ডাটাবেস সিস্টেম ACID প্রিন্সিপল অনুসরণ করে, যা ডাটাবেসের প্রতিটি ট্রানজেকশনের মানের নিশ্চয়তা প্রদান করে। এই চারটি প্রিন্সিপল ডাটাবেসের বিশ্বস্ততা এবং সঠিকতা নিশ্চিত করে।

1. Atomicity (আটমিকতা)

  • অর্থ: একটি ট্রানজেকশনের সমস্ত অপারেশন একসাথে সফল হবে অথবা সম্পূর্ণরূপে ব্যর্থ হবে। এর মানে হল যে, যদি একটি অপারেশন ব্যর্থ হয়, তবে পুরো ট্রানজেকশন বাতিল হবে এবং কোনো পরিবর্তন ডাটাবেসে থাকবে না।
  • উদাহরণ: যদি একটি ট্রানজেকশনে দুটি SQL অপারেশন থাকে, যেমন INSERT এবং UPDATE, এবং একটি অপারেশন ব্যর্থ হয়, তবে অন্য অপারেশনটি থাকবে না, সুতরাং সমস্ত পরিবর্তন ফিরিয়ে নেওয়া হবে।

2. Consistency (সঙ্গতি)

  • অর্থ: একটি ট্রানজেকশনের পর ডাটাবেসের অবস্থা সঙ্গতিপূর্ণ থাকতে হবে। অর্থাৎ, ডাটাবেসে কোনও অপারেশন করার পর সব কনস্ট্রেইন্ট এবং নিয়ম মেনে চলতে হবে। ডাটাবেসের অবস্থা ত্রুটিপূর্ণ হবে না।
  • উদাহরণ: যদি কোনো ট্রানজেকশনে একটি শর্ত ভুলভাবে পূর্ণ হয় (যেমন কোনো রেকর্ডে সীমিত মান ছাড়া ইনসার্ট করা হয়), তবে পুরো ট্রানজেকশন বাতিল হবে এবং ডাটাবেস সঠিক অবস্থায় ফিরে যাবে।

3. Isolation (অন্যথা)

  • অর্থ: একাধিক ট্রানজেকশন একসাথে সম্পাদিত হলেও, এক ট্রানজেকশন অন্য ট্রানজেকশনের দ্বারা প্রভাবিত হবে না। ট্রানজেকশনগুলো একে অপরের থেকে বিচ্ছিন্ন থাকবে, যেন সেগুলো একে অপরের পরিবর্তন দেখতে বা প্রভাবিত করতে না পারে।
  • উদাহরণ: যখন দুটি ট্রানজেকশন একসাথে চলতে থাকে, তখন একটির পরিবর্তন অন্যটির জন্য দৃশ্যমান হবে না যতক্ষণ না প্রথম ট্রানজেকশনটি কমপ্লিট না হয়।

4. Durability (স্থায়িত্ব)

  • অর্থ: একটি ট্রানজেকশন সফলভাবে কমপ্লিট হলে, তার পরিবর্তন ডাটাবেসে স্থায়ীভাবে সংরক্ষিত হবে। অর্থাৎ, ট্রানজেকশন শেষে ডাটাবেসে ডেটা হারানো বা পরিবর্তিত হবে না, এমনকি সিস্টেম ক্র্যাশ হলে বা পাওয়ার হারালেও।
  • উদাহরণ: একবার COMMIT করা হলে, পরিবর্তন ডাটাবেসে স্থায়ীভাবে সেভ হয়ে যাবে এবং সিস্টেম বন্ধ হলে তার কোনো ক্ষতি হবে না।

SQLite-এ Transactions এবং ACID Properties এর উদাহরণ

উদাহরণ ১: Atomicity

BEGIN TRANSACTION;
UPDATE account SET balance = balance - 100 WHERE id = 1;
UPDATE account SET balance = balance + 100 WHERE id = 2;
COMMIT;
  • এখানে দুটি UPDATE অপারেশন একটি ট্রানজেকশনে রয়েছে। যদি একটিতে কোনো সমস্যা ঘটে, পুরো ট্রানজেকশনটি বাতিল হবে।

উদাহরণ ২: Consistency

BEGIN TRANSACTION;
UPDATE account SET balance = balance - 100 WHERE id = 1;
-- Suppose the transaction fails here due to an error
ROLLBACK;
  • যদি কোনো ভুল হয় এবং ROLLBACK চালানো হয়, তবে পূর্বের পরিবর্তন বাতিল হয়ে যাবে, এবং ডাটাবেস পূর্বের অবস্থা বজায় রাখবে।

উদাহরণ ৩: Isolation

BEGIN TRANSACTION;
UPDATE account SET balance = balance - 100 WHERE id = 1;
-- At the same time, another transaction is trying to update the balance for the same account
BEGIN TRANSACTION;
UPDATE account SET balance = balance + 100 WHERE id = 1;
COMMIT;
COMMIT;
  • এখানে, প্রথম ট্রানজেকশন শেষ হওয়ার আগে দ্বিতীয়টি প্রভাবিত হবে না, এবং একে অপরের সম্পাদিত পরিবর্তন দেখতে পাবে না।

উদাহরণ ৪: Durability

BEGIN TRANSACTION;
INSERT INTO account (id, balance) VALUES (3, 1000);
COMMIT;
  • COMMIT হওয়ার পর, যে কোনো সিস্টেম ক্র্যাশেও ডেটা হারানো যাবে না এবং পরিবর্তন স্থায়ীভাবে ডাটাবেসে সংরক্ষিত হবে।

সারাংশ

SQLite Transactions এবং ACID Properties অনুসরণ করে যাতে ডাটাবেসে সব অপারেশন নির্ভরযোগ্য এবং নিরাপদ থাকে। Atomicity নিশ্চিত করে যে সমস্ত ট্রানজেকশন একসাথে সফল হবে, Consistency ডাটাবেসের সঠিক অবস্থা বজায় রাখে, Isolation নিশ্চিত করে যে একাধিক ট্রানজেকশন একে অপরকে প্রভাবিত করে না, এবং Durability নিশ্চিত করে যে সফল ট্রানজেকশনগুলোর পরিবর্তন স্থায়ীভাবে সংরক্ষিত থাকবে।

Content added By

SQLite এর Transaction Management

359

Transaction Management হল এমন একটি প্রক্রিয়া যা ডাটাবেসের সাথে ইন্টারঅ্যাকশন করার সময় ডেটার নিরাপত্তা এবং এক্সিকিউশনের ধারাবাহিকতা নিশ্চিত করে। SQLite-এ Transaction ব্যবহৃত হয় ডেটাবেসে একাধিক অপারেশন বা কর্মপরিকল্পনা (operations) সম্পাদন করার জন্য, যাতে তা সফলভাবে সম্পন্ন বা পুরোপুরি বাতিল (rollback) হয়।

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


ট্রানজেকশন কি?

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

ট্রানজেকশন সাপোর্টের মূল বৈশিষ্ট্য (ACID)

SQLite এ ট্রানজেকশন নিশ্চিত করতে ACID (Atomicity, Consistency, Isolation, Durability) গুণাবলী অনুসরণ করা হয়:

  • Atomicity (আণবিকতা): একটি ট্রানজেকশনের সমস্ত অপারেশন একযোগে সফল বা ব্যর্থ হবে। যদি একটিও অপারেশন ব্যর্থ হয়, পুরো ট্রানজেকশন বাতিল হবে।
  • Consistency (সামঞ্জস্য): ট্রানজেকশন শেষে ডাটাবেস সবসময় একটি বৈধ অবস্থায় থাকবে।
  • Isolation (স্বতন্ত্রতা): একাধিক ট্রানজেকশন একে অপরের থেকে আলাদা থাকবে এবং একটি ট্রানজেকশন অন্য ট্রানজেকশনের অপারেশনকে প্রভাবিত করবে না।
  • Durability (স্থিতিশীলতা): একবার ট্রানজেকশন সফলভাবে সম্পন্ন হলে, ডেটা স্থায়ীভাবে ডাটাবেসে সংরক্ষিত হবে।

SQLite-এ ট্রানজেকশন ব্যবহারের স্টেপস

  1. BEGIN TRANSACTION:

    • একটি ট্রানজেকশন শুরু করতে BEGIN TRANSACTION কমান্ড ব্যবহার করা হয়।
    BEGIN TRANSACTION;
    
  2. COMMIT:

    • যদি ট্রানজেকশনের সমস্ত অপারেশন সফলভাবে সম্পন্ন হয়, তবে COMMIT কমান্ড ব্যবহার করে পরিবর্তনগুলো ডাটাবেসে স্থায়ীভাবে সংরক্ষণ করা হয়।
    COMMIT;
    
  3. ROLLBACK:

    • যদি ট্রানজেকশনের কোনো অপারেশন ব্যর্থ হয়, তবে ROLLBACK কমান্ড ব্যবহার করে সমস্ত পরিবর্তন বাতিল করা হয় এবং ডাটাবেস পূর্বাবস্থায় ফিরে যায়।
    ROLLBACK;
    

ট্রানজেকশনের উদাহরণ

  1. সফল ট্রানজেকশন:

    • নিম্নলিখিত উদাহরণে, প্রথমে একটি নতুন users টেবিল তৈরি করা হয়, তার পর কিছু রেকর্ড ইনসার্ট করা হয়, এবং তারপর COMMIT করা হয়।
    BEGIN TRANSACTION;
    
    CREATE TABLE users (id INTEGER PRIMARY KEY, name TEXT, age INTEGER);
    
    INSERT INTO users (name, age) VALUES ('Alice', 30);
    INSERT INTO users (name, age) VALUES ('Bob', 25);
    
    COMMIT;
    

    এই ট্রানজেকশন সফলভাবে শেষ হলে, সমস্ত পরিবর্তন ডাটাবেসে স্থায়ীভাবে সংরক্ষিত হবে।

  2. ব্যর্থ ট্রানজেকশন (ROLLBACK):

    • যদি একটি ট্রানজেকশনের মধ্যে কোনো এক অপারেশন ব্যর্থ হয়, তবে ROLLBACK ব্যবহার করে পূর্বের সমস্ত অপারেশন বাতিল করা যাবে।
    BEGIN TRANSACTION;
    
    CREATE TABLE users (id INTEGER PRIMARY KEY, name TEXT, age INTEGER);
    
    INSERT INTO users (name, age) VALUES ('Alice', 30);
    INSERT INTO users (name, age) VALUES ('Bob', 'invalid_value');  -- ভুল ডেটা
    
    ROLLBACK;
    

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


SQLite ট্রানজেকশনের সুবিধা

  1. ডেটা নিরাপত্তা: ট্রানজেকশনের মাধ্যমে আপনি নিশ্চিত হতে পারেন যে সমস্ত ডেটাবেস অপারেশন সফলভাবে সম্পন্ন হয়েছে এবং কোনো অর্ধেক পরিবর্তন ডাটাবেসে থাকবে না।
  2. ডাটাবেসের অপরিবর্তনীয়তা: যখন ট্রানজেকশন সফলভাবে সম্পন্ন হয়, তখন সমস্ত পরিবর্তন স্থায়ীভাবে সংরক্ষিত হয়, যা ডেটা ক্ষতির ঝুঁকি কমায়।
  3. অপারেশনাল এক্সিকিউশন: একাধিক ডেটাবেস অপারেশন একসাথে সম্পাদন করার মাধ্যমে পারফরম্যান্স বৃদ্ধি পায় এবং ডাটাবেসকে একত্রিতভাবে পরিচালনা করা সহজ হয়।

সারাংশ

SQLite-এ Transaction Management আপনাকে ডেটাবেসে একাধিক অপারেশন সম্পাদন করার সময় ডেটার নিরাপত্তা এবং ধারাবাহিকতা নিশ্চিত করতে সাহায্য করে। BEGIN TRANSACTION, COMMIT, এবং ROLLBACK কমান্ডের মাধ্যমে আপনি ট্রানজেকশন শুরু, সফলভাবে সম্পন্ন, এবং ব্যর্থ হলে বাতিল করতে পারেন। ACID গুণাবলী অনুসরণ করে SQLite ডেটাবেসে কার্যকরী ট্রানজেকশন পরিচালনা নিশ্চিত করে।

Content added By

COMMIT, ROLLBACK, এবং SAVEPOINT ব্যবহার

277

SQLite সহ সমস্ত রিলেশনাল ডাটাবেস সিস্টেমে COMMIT, ROLLBACK, এবং SAVEPOINT ট্রানজেকশন ব্যবস্থাপনার জন্য ব্যবহৃত হয়। এগুলো ডেটার নিরাপত্তা, ট্রানজেকশন নিশ্চিতকরণ এবং ত্রুটির পরে ডেটার পুনরুদ্ধার নিশ্চিত করতে সহায়তা করে।


COMMIT

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

সিনট্যাক্স:

COMMIT;

ব্যবহার:

BEGIN TRANSACTION;

UPDATE users
SET age = 35
WHERE name = 'Alice';

COMMIT;

এখানে, BEGIN TRANSACTION দিয়ে ট্রানজেকশন শুরু করা হয়েছে এবং পরে COMMIT দিয়ে পরিবর্তনগুলো ডাটাবেসে স্থায়ীভাবে সংরক্ষণ করা হয়েছে।


ROLLBACK

ROLLBACK কমান্ডটি একটি ট্রানজেকশনের সমস্ত পরিবর্তন বাতিল করতে ব্যবহৃত হয়। যদি কোনো সমস্যা ঘটে, বা আপনি যদি চান না যে ট্রানজেকশনের পরিবর্তনগুলো ডাটাবেসে সংরক্ষিত হোক, তবে ROLLBACK কমান্ড ব্যবহার করা হয়।

সিনট্যাক্স:

ROLLBACK;

ব্যবহার:

BEGIN TRANSACTION;

UPDATE users
SET age = 35
WHERE name = 'Alice';

ROLLBACK;

এখানে, BEGIN TRANSACTION দিয়ে ট্রানজেকশন শুরু করা হয়েছে এবং ROLLBACK দিয়ে সেই পরিবর্তনগুলো বাতিল করা হয়েছে, ফলে Alice এর বয়স পরিবর্তন হবে না এবং ডাটাবেসে আগের মানই থাকবে।


SAVEPOINT

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

সিনট্যাক্স:

SAVEPOINT savepoint_name;

ব্যবহার:

BEGIN TRANSACTION;

UPDATE users
SET age = 35
WHERE name = 'Alice';

SAVEPOINT before_update;

UPDATE users
SET age = 40
WHERE name = 'Bob';

ROLLBACK TO before_update;

COMMIT;

এখানে, SAVEPOINT before_update দিয়ে একটি সেভ পয়েন্ট তৈরি করা হয়েছে এবং পরবর্তীতে ROLLBACK TO before_update ব্যবহার করে সেই পয়েন্টে ফিরে যাওয়া হয়েছে। এর ফলে Bob এর বয়স পরিবর্তন হয়নি, কিন্তু Alice এর বয়স পরিবর্তন হয়েছে এবং COMMIT দিয়ে পরিবর্তনগুলো ডাটাবেসে স্থায়ীভাবে সংরক্ষিত হয়েছে।


COMMIT, ROLLBACK, এবং SAVEPOINT এর মধ্যে পার্থক্য

  1. COMMIT:
    • সমস্ত পরিবর্তন স্থায়ীভাবে ডাটাবেসে সংরক্ষণ করে এবং ট্রানজেকশন শেষ করে।
  2. ROLLBACK:
    • ট্রানজেকশনের সমস্ত পরিবর্তন বাতিল করে এবং ডাটাবেসকে পূর্ববর্তী অবস্থায় ফিরিয়ে নিয়ে আসে। এটি পুরো ট্রানজেকশন রোলব্যাক করে।
  3. SAVEPOINT:
    • ট্রানজেকশনের মধ্যে একটি নির্দিষ্ট পয়েন্টে ফিরে যেতে সক্ষম করে, যাতে পুরো ট্রানজেকশন রোলব্যাক না করেও আপনি কিছু অংশের পরিবর্তন বাতিল করতে পারেন।

সারাংশ

COMMIT, ROLLBACK, এবং SAVEPOINT SQL ট্রানজেকশন ব্যবস্থাপনার গুরুত্বপূর্ণ কমান্ড। COMMIT ডাটাবেসে পরিবর্তনগুলো স্থায়ীভাবে সংরক্ষণ করে, ROLLBACK পরিবর্তনগুলো বাতিল করে এবং SAVEPOINT ট্রানজেকশনের মধ্যে একটি নির্দিষ্ট পয়েন্ট নির্ধারণ করে যাতে পরে প্রয়োজন হলে সেই পয়েন্টে ফিরে যাওয়া যায়। এই কমান্ডগুলো ব্যবহার করে ডেটা নিরাপত্তা এবং ট্রানজেকশন পরিচালনা করা যায়।

Content added By

SQLite এর ACID Properties (Atomicity, Consistency, Isolation, Durability)

349

SQLite একটি ACID-compliant ডাটাবেস সিস্টেম, যার মানে হলো এটি Atomicity, Consistency, Isolation, এবং Durability (ACID) এর সমস্ত প্রপার্টি অনুসরণ করে। এই প্রপার্টিগুলো ডাটাবেসের ট্রানজেকশনকে কার্যকরী, নির্ভরযোগ্য, এবং নিরাপদভাবে পরিচালনা করতে সাহায্য করে। ACID গুণাবলী ডাটাবেস সিস্টেমে ডাটা ইন্টিগ্রিটি এবং স্থিতিশীলতা নিশ্চিত করে, বিশেষত যখন সিস্টেম ক্র্যাশ বা অন্য কোনো সমস্যা হয়।

এখানে ACID এর প্রতিটি প্রপার্টি বিস্তারিতভাবে আলোচনা করা হলো:


১. Atomicity (পারমাণবিকতা)

Atomicity নিশ্চিত করে যে একটি ট্রানজেকশন সম্পূর্ণভাবে সফল বা সম্পূর্ণভাবে ব্যর্থ হবে। এর মানে হলো, ট্রানজেকশনটি যেকোনো ধরণের অংশে সফল হলে সম্পন্ন হবে, আর কোনো সমস্যা বা ব্যর্থতার কারণে পুরো ট্রানজেকশন বাতিল হবে।

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

SQLite-এ WAL (Write-Ahead Logging) মেকানিজম ব্যবহার করা হয়, যার মাধ্যমে Atomicity নিশ্চিত করা হয়। এক্ষেত্রে ডাটা প্রথমে WAL লগে লেখা হয় এবং পরে মূল ডাটাবেসে কমিট করা হয়।


২. Consistency (সামঞ্জস্য)

Consistency নিশ্চিত করে যে ট্রানজেকশনের মাধ্যমে ডাটাবেসের বর্তমান অবস্থা নিয়মিত এবং সঠিক থাকবে। অর্থাৎ, একটি ট্রানজেকশনের শুরুতে ডাটাবেস একটি সঠিক অবস্থায় থাকে এবং ট্রানজেকশন শেষ হওয়ার পরও তা সঠিক অবস্থায় থাকবে।

  • অর্থ: ডাটাবেসে ট্রানজেকশন চলাকালীন সময়ে কোনো ভুল বা অসামঞ্জস্যপূর্ণ অবস্থা সৃষ্টি হতে দেওয়া হবে না। যদি কোনো সমস্যা হয়, তবে ডাটাবেস আগের সঠিক অবস্থায় ফিরে যাবে (যেমন, ট্রানজেকশন সম্পূর্ণ না হলে আগের অবস্থায় ফিরে যাবে)।
  • উদাহরণ: যদি আপনি একটি অ্যাকাউন্টে টাকা জমা করার এবং অন্য অ্যাউন্ট থেকে টাকা কেটে নেওয়ার একটি ট্রানজেকশন চালান, তাহলে অ্যাকাউন্টের মোট ব্যালান্স পুরো ট্রানজেকশন চলাকালীন এবং পরে সঠিক থাকতে হবে।

SQLite-এ Consistency নিশ্চিত করতে প্রতিটি ট্রানজেকশন ACID প্রপার্টি অনুসরণ করে এবং rollback করার ক্ষমতা রাখে, যাতে ডাটাবেসে কোনো অসম্পূর্ণ বা ভুল ডেটা না থাকে।


৩. Isolation (অযথা মিশ্রণ প্রতিরোধ)

Isolation নিশ্চিত করে যে এক ট্রানজেকশনের পরিবর্তনগুলি অন্য ট্রানজেকশনগুলো থেকে আলাদা থাকে যতক্ষণ না ট্রানজেকশনটি সম্পূর্ণ হয়। অর্থাৎ, এক ট্রানজেকশন যখন চলমান থাকে, তখন অন্য কোনো ট্রানজেকশন সেই ডেটা পরিবর্তন করতে পারে না। একাধিক ট্রানজেকশন যদি একই ডেটার উপর কাজ করে, তবে তাদের মধ্যে কোনো ধরণের মিশ্রণ বা সংঘর্ষ ঘটবে না।

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

SQLite-এ Isolation নিশ্চিত করতে ACID ট্রানজেকশন চালানোর সময় locks ব্যবহৃত হয়, যা নিশ্চিত করে যে এক ট্রানজেকশনের পরবর্তী অপারেশন অন্য কোনো ট্রানজেকশনের দ্বারা প্রভাবিত হবে না।


৪. Durability (স্থিতিশীলতা)

Durability নিশ্চিত করে যে একটি ট্রানজেকশন সফলভাবে কমিট করার পর তার পরিবর্তনগুলি স্থায়ী হবে, এবং ডাটাবেস ক্র্যাশ বা সিস্টেম বন্ধ হয়ে গেলে ডেটা হারানো যাবে না। একটি ট্রানজেকশনের সমস্ত পরিবর্তন নিশ্চিতভাবে ডাটাবেসে সেভ হবে।

  • অর্থ: একবার ট্রানজেকশন কমিট হলে, সিস্টেম ডাউন বা বন্ধ হওয়ার পরও ডেটা থেকে যাবে এবং ডাটাবেস পুনরুদ্ধার হলে সঠিক তথ্য ফিরে আসবে।
  • উদাহরণ: ধরুন আপনি একটি অ্যাকাউন্টে টাকা জমা করার ট্রানজেকশন করেছেন। যদি আপনার কম্পিউটার হঠাৎ বন্ধ হয়ে যায়, তবে ট্রানজেকশনটি শেষ হওয়ার পরও আপনার জমাকৃত টাকা অক্ষত থাকবে।

SQLite-এ Durability নিশ্চিত করতে WAL (Write-Ahead Logging) পদ্ধতি ব্যবহার করা হয়। এই পদ্ধতিতে, ডাটা প্রথমে WAL ফাইলে লেখা হয় এবং পরে মূল ডাটাবেসে সেভ করা হয়, যা সিস্টেম ক্র্যাশের পরও ডাটা পুনরুদ্ধার নিশ্চিত করে।


সারাংশ

SQLite এর ACID প্রপার্টি (Atomicity, Consistency, Isolation, Durability) ডাটাবেসের সঠিক কার্যকারিতা ও নিরাপত্তা নিশ্চিত করে। Atomicity নিশ্চিত করে যে একটি ট্রানজেকশন সম্পূর্ণ বা ব্যর্থ হবে, Consistency নিশ্চিত করে যে ডাটাবেসের অবস্থা সঠিক থাকবে, Isolation নিশ্চিত করে যে এক ট্রানজেকশন অন্যটির দ্বারা প্রভাবিত হবে না, এবং Durability নিশ্চিত করে যে একটি ট্রানজেকশন কমিট হলে তার পরিবর্তন স্থায়ী থাকবে। এই বৈশিষ্ট্যগুলোর সমন্বয়ে SQLite ডাটাবেস ব্যবহারের সময় ডেটা নিরাপত্তা এবং স্থিতিশীলতা বজায় রাখে।

Content added By

Multi-Threaded Transactions এর ব্যবহার

313

SQLite একটি সার্ভারলেস ডেটাবেস সিস্টেম যা একাধিক থ্রেডের মাধ্যমে ডাটা অ্যাক্সেস এবং অপারেশন পরিচালনা করতে সক্ষম। তবে, SQLite ডিফল্টভাবে একক থ্রেড সাপোর্ট করে, অর্থাৎ একটি সময় একমাত্র একটি থ্রেড ডাটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারে। কিন্তু, SQLite এ multi-threaded transactions ব্যবহারের মাধ্যমে আপনি একাধিক থ্রেডকে ডাটাবেসে কার্যকরীভাবে কাজ করতে সক্ষম করতে পারেন।

SQLite তে multi-threaded transactions ব্যবহারের জন্য আপনাকে কিছু বিশেষ কনফিগারেশন এবং থ্রেড ম্যানেজমেন্টের দিকে খেয়াল রাখতে হবে।


SQLite Multi-Threading Modes

SQLite তে তিনটি থ্রেড সেফটি মোড থাকে:

  1. Single-thread mode:
    • ডিফল্ট মোড, যেখানে শুধুমাত্র একটি থ্রেড ডাটাবেসের সাথে যোগাযোগ করতে পারে।
    • অন্য থ্রেডের জন্য ডাটাবেসের অ্যাক্সেস অবরুদ্ধ থাকে।
  2. Multi-thread mode:
    • এখানে একাধিক থ্রেড ডাটাবেস অ্যাক্সেস করতে পারে, তবে একে অপরকে ব্লক করা বা প্রতিক্রিয়া দেয়া হয় না। এর মানে হল যে এক থ্রেড একটি ট্রানজেকশন শুরু করলে অন্য থ্রেড অন্য কোনো ডাটাবেস অপারেশন করতে পারে।
    • একাধিক থ্রেডের জন্য ডাটাবেস অ্যাক্সেস নিরাপদ, তবে এটি পারফরম্যান্সের জন্য কিছু সীমাবদ্ধতা নিয়ে আসে।
  3. Serialized mode:
    • সবচেয়ে নিরাপদ মোড যেখানে শুধুমাত্র একটি থ্রেড একসাথে ডাটাবেস অপারেশন সম্পাদন করতে পারে। অন্য কোনো থ্রেড ডাটাবেসের সাথে কাজ করার জন্য প্রথম থ্রেডের কাজ শেষ হতে অপেক্ষা করবে।
    • এটি থ্রেড সেফটি প্রদান করে, তবে এতে কিছু পারফরম্যান্স সমস্যা হতে পারে।

SQLite এ multi-threaded transactions সঠিকভাবে ব্যবহার করতে হলে আপনাকে PRAGMA নির্দেশিকা এবং বিশেষ থ্রেড সেফটি মোড ব্যবহারের দিকে নজর দিতে হবে।


Multi-Threaded Transactions ব্যবহার করতে PRAGMA নির্দেশিকা

SQLite তে PRAGMA নির্দেশিকা ব্যবহার করে আপনি থ্রেড সেফটি মোড কনফিগার করতে পারেন। নিচে কিছু উদাহরণ দেওয়া হলো:

১. Multi-threaded mode এ পরিবর্তন করা:

PRAGMA threadsafe=1;

এটি SQLite-কে multi-threaded মোডে চালানোর নির্দেশ দেবে। যদি আপনি SQLite অ্যাপ্লিকেশনে একাধিক থ্রেড ব্যবহার করেন, তবে এই নির্দেশিকার মাধ্যমে থ্রেড সেফটি সক্রিয় হবে।

২. Serialized mode এ পরিবর্তন করা:

PRAGMA threadsafe=2;

এটি SQLite-কে serialized মোডে চালানোর জন্য নির্দেশ দেবে, যেখানে একসাথে একাধিক থ্রেড ডাটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারে না।


Multi-Threaded Transactions ব্যবহারের উদাহরণ (Python)

SQLite তে Multi-Threaded Transactions ব্যবহার করার জন্য নিচে Python এর মাধ্যমে একটি উদাহরণ দেয়া হলো যেখানে একাধিক থ্রেড একসাথে ডাটাবেসে ট্রানজেকশন করতে সক্ষম হয়।

উদাহরণ: Python এ Multi-Threaded Transactions ব্যবহার

import sqlite3
import threading

# থ্রেডে কাজ করার জন্য একটি ফাংশন তৈরি করা
def insert_data(thread_id, conn):
    try:
        # ডাটাবেসে ইনসার্ট করা
        cursor = conn.cursor()
        cursor.execute("INSERT INTO users (name, age) VALUES (?, ?)", (f"User{thread_id}", thread_id + 20))
        conn.commit()
        print(f"Thread {thread_id}: Data inserted successfully.")
    except sqlite3.Error as e:
        print(f"Thread {thread_id}: Error - {e}")

# SQLite ডাটাবেস সংযোগ তৈরি করা
conn = sqlite3.connect('example.db', check_same_thread=False)  # check_same_thread=False allows multi-threading

# টেবিল তৈরি করা
conn.execute('''CREATE TABLE IF NOT EXISTS users (
                    id INTEGER PRIMARY KEY AUTOINCREMENT,
                    name TEXT,
                    age INTEGER)''')

# একাধিক থ্রেড চালানো
threads = []
for i in range(5):  # 5টি থ্রেড তৈরি করা
    thread = threading.Thread(target=insert_data, args=(i, conn))
    threads.append(thread)
    thread.start()

# সমস্ত থ্রেডের শেষ হওয়া পর্যন্ত অপেক্ষা করা
for thread in threads:
    thread.join()

# সংযোগ বন্ধ করা
conn.close()

ব্যাখ্যা:

  1. থ্রেড সেফটি সক্রিয় করা: check_same_thread=False দিয়ে SQLite কে multi-threaded mode এ চালানো হয়। এটি SQLite এ একাধিক থ্রেডের মাধ্যমে ডাটাবেসে কাজ করার অনুমতি দেয়।
  2. তিনটি ফাংশনাল থ্রেড: এখানে আমরা ৫টি আলাদা থ্রেড ব্যবহার করেছি যেগুলি একই ডাটাবেসে ইনসার্ট অপারেশন করতে সক্ষম।
  3. থ্রেডের সাথে ডাটাবেস ইন্টারঅ্যাকশন: প্রতিটি থ্রেড আলাদাভাবে ডাটাবেসে ডাটা ইনসার্ট করে এবং তাদের কাজ সফলভাবে শেষ হলে সেগুলি কমিট করে।

SQLite Multi-Threaded Transactions এর সুবিধা এবং সীমাবদ্ধতা

সুবিধা:

  1. পারফরম্যান্স বৃদ্ধি: একাধিক থ্রেডের মাধ্যমে ডাটাবেস অ্যাক্সেস করার ফলে পারফরম্যান্স কিছুটা বৃদ্ধি পেতে পারে, বিশেষত যখন একাধিক ইনপুট/আউটপুট (I/O) অপারেশন হচ্ছে।
  2. থ্রেড সেফটি: এটি অ্যাপ্লিকেশনের জন্য নিরাপদ, যেখানে একাধিক থ্রেড একই ডাটাবেস ফাইলের উপর কাজ করছে।
  3. সহজ কনফিগারেশন: আপনি PRAGMA নির্দেশিকা ব্যবহার করে সহজেই থ্রেড সেফটি মোড কনফিগার করতে পারেন।

সীমাবদ্ধতা:

  1. পারফরম্যান্স কম হতে পারে: অনেক থ্রেড একসাথে ডাটাবেস অ্যাক্সেস করলে পারফরম্যান্স কিছুটা কমে যেতে পারে, বিশেষত Serialized মোডে।
  2. কনকারেন্সি সমস্যা: যদি সঠিকভাবে থ্রেডিং ব্যবস্থাপনা না করা হয়, তবে ডাটাবেসে লকিং সমস্যা হতে পারে।

সারাংশ

SQLite তে Multi-Threaded Transactions ব্যবহার করার মাধ্যমে একাধিক থ্রেড ডাটাবেসের সাথে কাজ করতে সক্ষম হয়। এটি PRAGMA নির্দেশিকা ব্যবহার করে কনফিগার করা যায় এবং বিভিন্ন থ্রেড সেফটি মোড (যেমন, Multi-threaded mode এবং Serialized mode) সেট করা যায়। SQLite তে multi-threading পারফরম্যান্স এবং থ্রেড সেফটি নিশ্চিত করতে ব্যবহৃত হয়, তবে সঠিক ব্যবস্থাপনা প্রয়োজন, বিশেষত যখন একাধিক থ্রেড একই ডাটাবেস ফাইল অ্যাক্সেস করছে।

Content added By
Promotion

Are you sure to start over?

Loading...