Skill

বাস্তব উদাহরণ এবং ডেমো

এসকিউলাইট (SQLite) - Database Tutorials

408

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

আমরা Flask (Python ফ্রেমওয়ার্ক) ব্যবহার করে SQLite ইন্টিগ্রেশন দেখাবো। এটি একটি সাধারণ ওয়েব অ্যাপ্লিকেশন হবে যা ইউজারদের নাম এবং পাসওয়ার্ড সংরক্ষণ করবে এবং লগইন ও রেজিস্ট্রেশন ফিচার সরবরাহ করবে।


Flask অ্যাপ্লিকেশন সেটআপ

প্রথমে, Flask ইনস্টল করতে হবে:

pip install flask

এরপর, একটি নতুন Python ফাইল তৈরি করুন (যেমন: app.py) এবং নিচের কোডটি ব্যবহার করুন:

Flask অ্যাপ্লিকেশন কোড

from flask import Flask, request, render_template, redirect, url_for
import sqlite3

app = Flask(__name__)

# ডাটাবেস তৈরি করা
def init_db():
    conn = sqlite3.connect('users.db')
    c = conn.cursor()
    c.execute('''CREATE TABLE IF NOT EXISTS users (
                    id INTEGER PRIMARY KEY AUTOINCREMENT,
                    username TEXT UNIQUE NOT NULL,
                    password TEXT NOT NULL)''')
    conn.commit()
    conn.close()

# রেজিস্ট্রেশন ফর্ম প্রদর্শন
@app.route('/register', methods=['GET', 'POST'])
def register():
    if request.method == 'POST':
        username = request.form['username']
        password = request.form['password']

        # ডাটাবেসে ইউজার যুক্ত করা
        conn = sqlite3.connect('users.db')
        c = conn.cursor()
        try:
            c.execute('INSERT INTO users (username, password) VALUES (?, ?)', (username, password))
            conn.commit()
            return redirect(url_for('login'))
        except sqlite3.IntegrityError:
            return 'Username already exists!'
        finally:
            conn.close()

    return render_template('register.html')

# লগইন ফর্ম প্রদর্শন
@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'POST':
        username = request.form['username']
        password = request.form['password']

        # ডাটাবেসে ইউজার যাচাই করা
        conn = sqlite3.connect('users.db')
        c = conn.cursor()
        c.execute('SELECT * FROM users WHERE username=? AND password=?', (username, password))
        user = c.fetchone()
        conn.close()

        if user:
            return 'Logged in successfully!'
        else:
            return 'Invalid credentials!'
    
    return render_template('login.html')

# হোম পেজ
@app.route('/')
def home():
    return 'Welcome to the User Management System!'

if __name__ == '__main__':
    init_db()  # ডাটাবেস ইনিশিয়ালাইজ করা
    app.run(debug=True)

HTML ফাইল তৈরি

  1. register.html (রেজিস্ট্রেশন ফর্ম):
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Register</title>
</head>
<body>
    <h1>Register</h1>
    <form action="/register" method="post">
        <label for="username">Username:</label><br>
        <input type="text" id="username" name="username" required><br><br>
        <label for="password">Password:</label><br>
        <input type="password" id="password" name="password" required><br><br>
        <button type="submit">Register</button>
    </form>
    <br><a href="/login">Already have an account? Login here</a>
</body>
</html>
  1. login.html (লগইন ফর্ম):
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Login</title>
</head>
<body>
    <h1>Login</h1>
    <form action="/login" method="post">
        <label for="username">Username:</label><br>
        <input type="text" id="username" name="username" required><br><br>
        <label for="password">Password:</label><br>
        <input type="password" id="password" name="password" required><br><br>
        <button type="submit">Login</button>
    </form>
    <br><a href="/register">Don't have an account? Register here</a>
</body>
</html>

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

  1. ডাটাবেস ইনিশিয়ালাইজেশন: init_db() ফাংশনটি ডাটাবেস এবং users টেবিল তৈরি করে।
  2. রেজিস্ট্রেশন: /register রুটে একটি ফর্ম প্রদর্শিত হবে যেখানে ইউজার নাম এবং পাসওয়ার্ড ইনপুট করতে পারবেন। ইউজার নাম যদি আগে থেকেই ডাটাবেসে থাকে, তাহলে এটি IntegrityError প্রদর্শন করবে।
  3. লগইন: /login রুটে ইউজার নাম এবং পাসওয়ার্ড দিয়ে লগইন করতে হবে। যদি ডাটাবেসে দেওয়া তথ্যের সাথে মেলে, তাহলে সিস্টেম ইউজারকে লগইন করবে, অন্যথায় Invalid credentials দেখাবে।
  4. SQLite ব্যবহার: SQLite ডাটাবেসে ইউজার তথ্য ইনসার্ট এবং যাচাই করতে sqlite3 লাইব্রেরি ব্যবহৃত হচ্ছে।

ডেমো রান করা

  1. আপনার Python ফাইল (app.py) এবং HTML ফাইলগুলো তৈরি করার পর, Flask অ্যাপ রান করুন:

    python app.py
    
  2. তারপর, ব্রাউজারে গিয়ে এই URL দেখুন: http://127.0.0.1:5000/
    • Register পেজে যান এবং একটি নতুন ইউজার নিবন্ধন করুন।
    • তারপর Login পেজে গিয়ে নিবন্ধিত ইউজার দিয়ে লগইন করুন।

সারাংশ

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

Content added By

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


১. SQLite ডেটাবেস তৈরি করা

SQLite-এ একটি নতুন ডেটাবেস তৈরি করতে আপনি sqlite3 কমান্ড ব্যবহার করতে পারেন। এই কমান্ডটি একটি নতুন SQLite ডেটাবেস ফাইল তৈরি করবে।

ডেটাবেস তৈরি করা:

sqlite3 mydatabase.db
  • এখানে, mydatabase.db একটি নতুন ডেটাবেস ফাইল তৈরি করবে (যদি এটি পূর্বে তৈরি না থাকে)। যদি এটি আগে থেকে থাকে, তবে তা খোলার চেষ্টা করবে।

২. টেবিল তৈরি করা

SQLite-এ একটি নতুন টেবিল তৈরি করতে CREATE TABLE কমান্ড ব্যবহার করা হয়। টেবিলের মধ্যে কলামগুলো এবং তাদের ডেটা টাইপ নির্ধারণ করা হয়।

উদাহরণ: একটি users টেবিল তৈরি করা

CREATE TABLE users (
    id INTEGER PRIMARY KEY,
    name TEXT NOT NULL,
    age INTEGER,
    email TEXT UNIQUE
);
  • এখানে, id কলামটি Primary Key হিসেবে নির্বাচিত হয়েছে, যার মান ইউনিক হবে এবং NOT NULL হতে হবে।
  • email কলামটি Unique হওয়া উচিত, যার মান একাধিক রেকর্ডে হতে পারবে না।

৩. ডেটা ইনসার্ট করা

SQLite-এ ডেটা ইনসার্ট করতে INSERT INTO কমান্ড ব্যবহার করা হয়। আপনি টেবিলের নির্দিষ্ট কলামে ডেটা প্রদান করেন।

উদাহরণ: users টেবিলে ডেটা ইনসার্ট করা

INSERT INTO users (name, age, email) 
VALUES ('John Doe', 30, 'john.doe@example.com');

এই কমান্ডটি users টেবিলে একটি নতুন রেকর্ড ইনসার্ট করবে, যেখানে name, age, এবং email কলামে মান ইনসার্ট করা হবে।

একাধিক রেকর্ড ইনসার্ট করা:

INSERT INTO users (name, age, email) 
VALUES 
    ('Alice', 25, 'alice@example.com'),
    ('Bob', 35, 'bob@example.com');

এটি একসাথে দুটি রেকর্ড ইনসার্ট করবে।


৪. ডেটা নির্বাচন (Select) করা

SQLite-এ ডেটা নির্বাচন করতে SELECT কমান্ড ব্যবহার করা হয়। এটি একটি টেবিল থেকে ডেটা ফিল্টার করার জন্য বিভিন্ন শর্ত ব্যবহার করতে পারে।

উদাহরণ: users টেবিল থেকে সমস্ত ডেটা নির্বাচন করা

SELECT * FROM users;

এটি users টেবিলের সমস্ত রেকর্ড নির্বাচন করবে।

নির্দিষ্ট কলাম নির্বাচন করা:

SELECT name, age FROM users;

এটি users টেবিল থেকে শুধুমাত্র name এবং age কলাম নির্বাচন করবে।


৫. ডেটা আপডেট (Update) করা

SQLite-এ কোনো ডেটা আপডেট করতে UPDATE কমান্ড ব্যবহার করা হয়। নির্দিষ্ট শর্তের ভিত্তিতে কলামের মান পরিবর্তন করা হয়।

উদাহরণ: users টেবিলের ডেটা আপডেট করা

UPDATE users
SET age = 31
WHERE name = 'John Doe';

এটি users টেবিলের name কলামে 'John Doe' এর জন্য age কলামকে 31 দিয়ে আপডেট করবে।


৬. ডেটা মুছা (Delete) করা

SQLite-এ কোনো রেকর্ড মুছতে DELETE কমান্ড ব্যবহার করা হয়। এটি টেবিল থেকে নির্দিষ্ট রেকর্ড মুছে ফেলে।

উদাহরণ: users টেবিল থেকে একটি রেকর্ড মুছা

DELETE FROM users
WHERE name = 'Alice';

এটি users টেবিল থেকে name কলামে 'Alice' এর রেকর্ড মুছে ফেলবে।

সমস্ত রেকর্ড মুছা:

DELETE FROM users;

এটি users টেবিলের সমস্ত রেকর্ড মুছে ফেলবে।


৭. টেবিল পরিবর্তন (Alter) করা

SQLite-এ একটি টেবিলের কাঠামো পরিবর্তন করতে ALTER TABLE কমান্ড ব্যবহার করা হয়।

উদাহরণ: একটি নতুন কলাম যোগ করা

ALTER TABLE users
ADD COLUMN phone_number TEXT;

এটি users টেবিলে একটি নতুন phone_number কলাম যোগ করবে।


৮. টেবিল মুছা (Drop) করা

SQLite-এ একটি টেবিল মুছতে DROP TABLE কমান্ড ব্যবহার করা হয়।

উদাহরণ: users টেবিল মুছা

DROP TABLE users;

এটি users টেবিলটি মুছে ফেলবে এবং সমস্ত ডেটা হারিয়ে যাবে।


৯. ইন্ডেক্স তৈরি (Create Index)

SQLite-এ Index ব্যবহার করে ডেটার দ্রুত অনুসন্ধান করা যায়। একাধিক কলাম বা টেবিলের উপর ইনডেক্স তৈরি করা যেতে পারে।

উদাহরণ: একটি ইনডেক্স তৈরি করা

CREATE INDEX idx_users_name ON users (name);

এটি users টেবিলের name কলামে একটি ইনডেক্স তৈরি করবে, যার ফলে name কলামের ডেটা দ্রুত অনুসন্ধান করা যাবে।


সারাংশ

SQLite-এ ডেটাবেস এবং টেবিল ম্যানিপুলেশন অত্যন্ত সহজ এবং কার্যকরী। আপনি SQLite কমান্ড ব্যবহার করে নতুন ডেটাবেস এবং টেবিল তৈরি, ডেটা ইনসার্ট, আপডেট, সিলেক্ট, ডিলিট এবং টেবিলের কাঠামো পরিবর্তন করতে পারেন। এটি ছোট এবং মাঝারি আকারের অ্যাপ্লিকেশনগুলির জন্য খুবই উপকারী, বিশেষ করে যেখানে সার্ভারবিহীন ডাটাবেস প্রয়োজন।

Content added By

Stored Procedure এবং Trigger ডাটাবেসের মধ্যে অটোমেশন এবং লজিক প্রক্রিয়াকে সহজতর করার জন্য ব্যবহৃত হয়। তারা বিশেষ ধরনের SQL স্ক্রিপ্ট যা ডাটাবেসে সেভ করা হয় এবং বিভিন্ন শর্তে অথবা একটি নির্দিষ্ট ইভেন্টে এক্সিকিউট হয়। চলুন, তাদের বাস্তব উদাহরণ দেখি।


১. Stored Procedure

Stored Procedure হলো একটি প্রি-কম্পাইলড SQL কোডের সেট যা ডাটাবেসে সংরক্ষিত থাকে এবং যখন প্রয়োজন হয় তখন কল করা হয়। এটি পুনরায় ব্যবহারযোগ্য এবং ডাটাবেসে লজিক পরিচালনা করতে সহায়তা করে।

বাস্তব উদাহরণ:

ধরা যাক, আপনার একটি orders টেবিল আছে যেখানে আপনি গ্রাহকের অর্ডারের মোট মূল্য এবং ডিসকাউন্ট হিসাব করতে চান। এই কাজটি স্বয়ংক্রিয় করতে একটি Stored Procedure তৈরি করা যায়।

orders টেবিল:
order_idcustomer_idorder_amountdiscount
11015000
210210000
Stored Procedure:
DELIMITER CREATEPROCEDURECalculateDiscount(INcustomeridINT)BEGINDECLAREtotalamountDECIMAL(10,2);--িSELECTSUM(orderamount)INTOtotalamountFROMordersWHEREcustomerid=customerid;--িIFtotalamount>1000THENUPDATEordersSETdiscount=10WHEREcustomerid=customerid;ELSEUPDATEordersSETdiscount=0WHEREcustomerid=customerid;ENDIF;END

CREATE PROCEDURE CalculateDiscount(IN customer_id INT)
BEGIN
    DECLARE total_amount DECIMAL(10, 2);
    
    -- গ্রাহকের মোট অর্ডার পরিমাণ বের করা
    SELECT SUM(order_amount) INTO total_amount
    FROM orders
    WHERE customer_id = customer_id;
    
    -- ডিসকাউন্ট প্রযোজ্য করা
    IF total_amount > 1000 THEN
        UPDATE orders
        SET discount = 10
        WHERE customer_id = customer_id;
    ELSE
        UPDATE orders
        SET discount = 0
        WHERE customer_id = customer_id;
    END IF;
END

DELIMITER ;
Stored Procedure কল করা:
CALL CalculateDiscount(101);

এই Stored Procedure customer_id অনুযায়ী মোট অর্ডার পরিমাণ বের করবে এবং সেই অনুযায়ী ডিসকাউন্ট প্রযোজ্য করবে। যদি গ্রাহকের মোট অর্ডার 1000 এর বেশি হয়, তবে 10% ডিসকাউন্ট দেওয়া হবে।


২. Trigger

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

বাস্তব উদাহরণ:

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

employees টেবিল:
employee_idnamesalary
1Alice50000
2Bob60000
audit_log টেবিল:
log_idemployee_idactionold_salarynew_salarytimestamp
11Salary UpdateNULL500002024-11-01 10:00:00
22Salary UpdateNULL600002024-11-01 11:00:00
Trigger তৈরি করা:
CREATE TRIGGER SalaryUpdateTrigger
AFTER UPDATE ON employees
FOR EACH ROW
BEGIN
    -- যদি salary পরিবর্তিত হয়, তাহলে audit_log এ নতুন রেকর্ড যোগ করা হবে
    IF OLD.salary != NEW.salary THEN
        INSERT INTO audit_log (employee_id, action, old_salary, new_salary, timestamp)
        VALUES (NEW.employee_id, 'Salary Update', OLD.salary, NEW.salary, NOW());
    END IF;
END;
Trigger ব্যাখ্যা:
  • Trigger Type: AFTER UPDATE — এটি employees টেবিলের update অপারেশন সম্পন্ন হওয়ার পরে কার্যকর হবে।
  • Condition: IF OLD.salary != NEW.salary — অর্থাৎ, যদি পুরনো এবং নতুন স্যালারি আলাদা হয়, তখন audit_log টেবিলে নতুন একটি রেকর্ড সন্নিবেশ করা হবে।
  • Action: স্যালারি পরিবর্তনের তথ্য audit_log টেবিলে সন্নিবেশ করা।
Trigger কার্যক্রম:
  1. আপনি যখন employees টেবিলে একটি স্যালারি আপডেট করবেন:
UPDATE employees SET salary = 55000 WHERE employee_id = 1;
  1. তখন audit_log টেবিলে এই পরিবর্তনটি লগ হবে:
log_idemployee_idactionold_salarynew_salarytimestamp
11Salary Update50000550002024-11-01 12:00:00

সারাংশ

Stored Procedure এবং Trigger ডাটাবেসের কার্যকারিতা এবং অটোমেশন উন্নত করতে ব্যবহৃত হয়:

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

দুটি টুলই ডাটাবেসের কার্যক্রম সহজতর করে এবং ডেটার ইন্টিগ্রিটি বজায় রাখার জন্য অত্যন্ত উপকারী।

Content added By

JSON এবং Full-Text Search (FTS) হল ডাটাবেসে ডেটার সঞ্চয় এবং অনুসন্ধানের দুটি শক্তিশালী কৌশল। SQLite-এ JSON ডেটা সংরক্ষণ এবং বিশ্লেষণ করার জন্য প্রয়োজনীয় ফিচারগুলি এবং Full-Text Search (FTS) কুয়েরি ইঞ্জিন ব্যবহার করে আপনার ডেটাবেসে দ্রুত এবং কার্যকরী অনুসন্ধান করা যায়।

SQLite-এ JSON এবং FTS ব্যবহারের মাধ্যমে আপনি আরও কার্যকরী ডেটা পরিচালনা এবং দ্রুত অনুসন্ধান করতে পারবেন। নিচে JSON এবং Full-Text Search-এর মধ্যে ব্যবহারের পদ্ধতি এবং তাদের সুবিধা আলোচনা করা হলো।


১. JSON এর ব্যবহার

SQLite 3.9.0 সংস্করণ থেকে JSON1 Extension অন্তর্ভুক্ত করা হয়েছে, যা SQLite ডাটাবেসে JSON ডেটা সংরক্ষণ এবং পরিচালনা করার সুবিধা প্রদান করে। SQLite-এ JSON ডেটা TEXT টাইপ কলামে সংরক্ষণ করা হয়, এবং JSON সম্পর্কিত অপারেশন করতে JSON1 এক্সটেনশন ফাংশন ব্যবহার করা হয়।

JSON ডেটা সংরক্ষণ:

SQLite-এ JSON ডেটা স্টোর করতে সাধারণত TEXT টাইপ কলাম ব্যবহার করা হয়, যা JSON ফরম্যাটে ডেটা সংরক্ষণ করে।

CREATE TABLE users (
    id INTEGER PRIMARY KEY,
    name TEXT,
    data TEXT
);

এখানে data কলামে JSON ডেটা সংরক্ষণ করা হবে।

JSON ডেটা ইনসার্ট করা:

SQLite-এ JSON ডেটা ইনসার্ট করার জন্য সাধারণত JSON ফরম্যাট ব্যবহার করা হয়:

INSERT INTO users (name, data) 
VALUES ('Alice', '{"age": 30, "email": "alice@example.com", "is_active": true}');

এটি users টেবিলে name এবং data কলামে JSON ডেটা ইনসার্ট করবে।

JSON ডেটা অনুসন্ধান:

SQLite-এ JSON ডেটা অনুসন্ধান করতে JSON1 Extension ফাংশন ব্যবহার করা হয়। উদাহরণস্বরূপ, যদি আপনি data কলামে age এর মান অনুসন্ধান করতে চান, তাহলে json_extract ফাংশন ব্যবহার করা হবে:

SELECT name, json_extract(data, '$.age') AS age 
FROM users
WHERE json_extract(data, '$.age') > 25;

এই কুয়েরিটি users টেবিল থেকে age এর মান ২৫ এর বেশি এমন ব্যবহারকারীদের তথ্য বের করবে।

JSON ডেটা আপডেট করা:

JSON ডেটা আপডেট করতে json_set ফাংশন ব্যবহার করা হয়:

UPDATE users
SET data = json_set(data, '$.age', 31)
WHERE name = 'Alice';

এটি users টেবিলের Alice নামের ব্যবহারকারীর age ক্ষেত্র আপডেট করবে।


২. Full-Text Search (FTS) এর ব্যবহার

SQLite-এ Full-Text Search (FTS) একটি বিশেষ সুবিধা যা ডেটাবেসে টেক্সট ডেটার দ্রুত এবং কার্যকরী অনুসন্ধান করতে ব্যবহৃত হয়। FTS ইনডেক্স ব্যবহার করে আপনি টেক্সট ফিল্ডগুলিতে কীওয়ার্ড অনুসন্ধান এবং ডাটা ফিল্টার করতে পারেন।

SQLite-এ FTS ইমপ্লিমেন্টেশনের জন্য দুটি প্রধান ধরনের ইনডেক্স রয়েছে:

  1. FTS3: সাধারণ Full-Text Search মডেল।
  2. FTS4: FTS3 এর উন্নত সংস্করণ, যা কিছু অতিরিক্ত বৈশিষ্ট্য প্রদান করে।

FTS টেবিল তৈরি করা:

SQLite-এ FTS টেবিল তৈরি করতে CREATE VIRTUAL TABLE কমান্ড ব্যবহার করা হয়। উদাহরণস্বরূপ, যদি আপনি একটি articles টেবিল তৈরি করতে চান যা FTS অনুসন্ধান সক্ষম:

CREATE VIRTUAL TABLE articles USING fts4(title, content);

এখানে articles টেবিল দুটি কলাম title এবং content ধারণ করবে, এবং এই কলামগুলির মধ্যে FTS অনুসন্ধান করতে পারবেন।

FTS টেবিলে ডেটা ইনসার্ট করা:

INSERT INTO articles (title, content)
VALUES ('SQLite Tutorial', 'This is a tutorial on how to use SQLite with React Native.'),
       ('React Native Basics', 'Learn the basics of React Native framework.');

এটি articles টেবিলে দুটি রেকর্ড ইনসার্ট করবে।

FTS অনুসন্ধান করা:

SQLite-এ FTS অনুসন্ধান করতে MATCH অপারেটর ব্যবহার করা হয়। উদাহরণস্বরূপ, যদি আপনি articles টেবিলে এমন ডেটা খুঁজতে চান যেখানে SQLite শব্দটি রয়েছে:

SELECT title, content
FROM articles
WHERE content MATCH 'SQLite';

এটি articles টেবিল থেকে এমন সব রেকর্ড নির্বাচন করবে, যেখানে content কলামে SQLite শব্দটি রয়েছে।

FTS ইনডেক্স অপটিমাইজেশন:

FTS টেবিলটি বড় হলে, আপনি PRAGMA optimize ব্যবহার করে ইনডেক্স অপটিমাইজ করতে পারেন:

PRAGMA optimize;

এই কুয়েরি ইনডেক্সের পারফরম্যান্স উন্নত করবে।


JSON এবং FTS এর সমন্বয়

SQLite-এ আপনি JSON ডেটা এবং FTS ব্যবহার করে একত্রে কাজ করতে পারেন, যা উন্নত অনুসন্ধান এবং বিশ্লেষণ করতে সহায়তা করে। উদাহরণস্বরূপ, আপনি JSON ফিল্ডের মধ্যে সংরক্ষিত ডেটা অনুসন্ধান করতে পারেন এবং সেই ডেটার মধ্যে কীওয়ার্ডের সাথে মিলে এমন টেক্সট রেকর্ড ফিল্টার করতে পারেন।

JSON এবং FTS এর সমন্বয়ে অনুসন্ধান:

SELECT title, json_extract(data, '$.category') AS category
FROM articles
WHERE content MATCH 'SQLite'
AND json_extract(data, '$.category') = 'Database';

এটি articles টেবিল থেকে content কলামে SQLite শব্দটি এবং category কলামে Database মান থাকা রেকর্ডগুলো নির্বাচন করবে।


সারাংশ

SQLite-এ JSON এবং Full-Text Search (FTS) ব্যবহারের মাধ্যমে আপনি ডেটাবেসের ডেটা স্টোরেজ এবং অনুসন্ধান দক্ষতার সাথে পরিচালনা করতে পারেন। JSON ফাংশনগুলি JSON ডেটা সংরক্ষণ এবং বিশ্লেষণ করতে সাহায্য করে, এবং FTS আপনাকে দ্রুত এবং কার্যকরী টেক্সট অনুসন্ধান করতে সহায়তা করে। এই দুটি প্রযুক্তির সমন্বয় আপনার অ্যাপ্লিকেশনে শক্তিশালী ডেটাবেস ফিচার যোগ করে, যেমন উন্নত অনুসন্ধান এবং ডেটা বিশ্লেষণ।

Content added By

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


১. Mobile Application এ SQLite Integration

SQLite মোবাইল অ্যাপ্লিকেশনগুলোতে ডেটা সংরক্ষণের জন্য খুব জনপ্রিয়। বিশেষত Android এবং iOS অ্যাপ্লিকেশনগুলোতে SQLite ব্যবহৃত হয়। এখানে একটি Android অ্যাপ্লিকেশন এর মধ্যে SQLite এর ইন্টিগ্রেশন উদাহরণ দেওয়া হলো।

Android SQLite Integration উদাহরণ

Step 1: SQLiteHelper ক্লাস তৈরি করা

Android অ্যাপ্লিকেশনে SQLite ডাটাবেস পরিচালনা করার জন্য প্রথমে একটি SQLiteOpenHelper ক্লাস তৈরি করতে হবে। এই ক্লাসটি ডাটাবেস তৈরি এবং ম্যানেজমেন্ট করবে।

public class DatabaseHelper extends SQLiteOpenHelper {

    private static final String DATABASE_NAME = "mydatabase.db";
    private static final int DATABASE_VERSION = 1;
    private static final String TABLE_NAME = "users";
    
    public static final String COLUMN_ID = "id";
    public static final String COLUMN_NAME = "name";
    public static final String COLUMN_EMAIL = "email";
    
    public DatabaseHelper(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        String CREATE_USERS_TABLE = "CREATE TABLE " + TABLE_NAME + " (" +
                COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
                COLUMN_NAME + " TEXT, " +
                COLUMN_EMAIL + " TEXT)";
        db.execSQL(CREATE_USERS_TABLE);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
        onCreate(db);
    }

    // Method to insert a user into the database
    public void addUser(String name, String email) {
        SQLiteDatabase db = this.getWritableDatabase();
        ContentValues values = new ContentValues();
        values.put(COLUMN_NAME, name);
        values.put(COLUMN_EMAIL, email);
        db.insert(TABLE_NAME, null, values);
        db.close();
    }
    
    // Method to retrieve all users
    public Cursor getAllUsers() {
        SQLiteDatabase db = this.getReadableDatabase();
        return db.query(TABLE_NAME, null, null, null, null, null, null);
    }
}

Step 2: SQLite ডাটাবেস ব্যবহার করা

এখন আপনি DatabaseHelper ক্লাস ব্যবহার করে ডেটা ইনসার্ট এবং রিট্রিভ করতে পারবেন।

public class MainActivity extends AppCompatActivity {

    private DatabaseHelper dbHelper;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        dbHelper = new DatabaseHelper(this);

        // Inserting data
        dbHelper.addUser("John Doe", "john.doe@example.com");

        // Retrieving data
        Cursor cursor = dbHelper.getAllUsers();
        if (cursor.moveToFirst()) {
            do {
                String name = cursor.getString(cursor.getColumnIndex("name"));
                String email = cursor.getString(cursor.getColumnIndex("email"));
                Log.d("User", "Name: " + name + ", Email: " + email);
            } while (cursor.moveToNext());
        }
        cursor.close();
    }
}

এই কোডটি Android অ্যাপ্লিকেশনে SQLite ডাটাবেস তৈরি, ডেটা ইনসার্ট এবং ডেটা রিট্রিভ করার উদাহরণ প্রদান করে।


২. Web Application এ SQLite Integration

SQLite সাধারণত ওয়েব অ্যাপ্লিকেশনে ব্যবহৃত হয় যখন ডাটাবেস সার্ভার বা ক্লাউড সমাধান ব্যবহার করতে না হয় বা সিঙ্গল ইউজার অ্যাপ্লিকেশন থাকে। ওয়েব অ্যাপ্লিকেশনে SQLite ব্যবহার করার জন্য PHP বা Node.js ব্যবহার করা যেতে পারে।

PHP SQLite Integration উদাহরণ

Step 1: SQLite ডাটাবেস তৈরি করা এবং কনফিগার করা

<?php
// Create or open SQLite database
$db = new SQLite3('mydatabase.db');

// Create a table
$query = "CREATE TABLE IF NOT EXISTS users (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    name TEXT,
    email TEXT
)";
$db->exec($query);

// Insert data
$query = "INSERT INTO users (name, email) VALUES ('John Doe', 'john.doe@example.com')";
$db->exec($query);

// Retrieve data
$result = $db->query('SELECT * FROM users');
while ($row = $result->fetchArray()) {
    echo "ID: " . $row['id'] . " Name: " . $row['name'] . " Email: " . $row['email'] . "<br>";
}

$db->close();
?>

Step 2: PHP কোডের মাধ্যমে SQLite ডাটাবেস ব্যবহার করা

এটি PHP এর মাধ্যমে SQLite ডাটাবেসে ডেটা ইনসার্ট এবং রিট্রিভ করার উদাহরণ। এখানে SQLite3 ক্লাস ব্যবহার করে ডাটাবেস তৈরি করা, টেবিল তৈরি করা এবং ডেটা ইনসার্ট ও রিট্রিভ করা হয়েছে।


সারাংশ

Mobile Applications (যেমন Android) এবং Web Applications (যেমন PHP বা Node.js সহ) উভয় ক্ষেত্রে SQLite ইন্টিগ্রেশন খুবই সহজ এবং কার্যকরী। Android অ্যাপ্লিকেশনে, SQLiteOpenHelper ক্লাস ব্যবহার করে ডাটাবেস তৈরি এবং পরিচালনা করা যায়, যেখানে PHP ওয়েব অ্যাপ্লিকেশনে SQLite3 ক্লাস ব্যবহার করে একই কাজ করা হয়। SQLite এর সুবিধা হল এটি কম রিসোর্স নিয়ে কাজ করে এবং ছোট-আকারের অ্যাপ্লিকেশনগুলির জন্য আদর্শ।

Content added By
Promotion

Are you sure to start over?

Loading...