Database Tutorials Collection তৈরি এবং Schema Design গাইড ও নোট

340

MongoDB একটি NoSQL ডেটাবেস, যেখানে ডেটা Collection নামক ধারণায় সংরক্ষিত হয়। MongoDB তে কোনও নির্দিষ্ট স্কিমা বা কাঠামো নেই, তাই এটি স্কিমা-লেস ডেটাবেস। তবে, যখন আপনি ডেটা ডিজাইন করেন, তখন কিছু সাধারণ নকশা এবং সেরা অনুশীলন অনুসরণ করা গুরুত্বপূর্ণ, যাতে ডেটাবেসটি কার্যকরী এবং কার্যকরী হয়। MongoDB তে Collection তৈরি করা এবং সঠিক Schema Design গুরুত্বপূর্ণ হতে পারে, বিশেষত যখন আপনি বড় অ্যাপ্লিকেশন তৈরি করছেন।


1. MongoDB Collection তৈরি

MongoDB তে ডেটা সংরক্ষণ করা হয় Collection নামে। Collection হল ডেটাবেসের মধ্যে একটি গোষ্ঠী, যার মধ্যে ডকুমেন্ট থাকে। MongoDB তে কলেকশন তৈরি করার জন্য আপনাকে কোনো CREATE কমান্ড ব্যবহার করতে হয় না; ডেটা ইনসার্ট করার সময় MongoDB স্বয়ংক্রিয়ভাবে কলেকশন তৈরি করে।

Collection তৈরি করার উদাহরণ:

  1. ডেটাবেস নির্বাচন করা: প্রথমে আপনি একটি ডেটাবেস নির্বাচন করবেন। MongoDB তে ডেটাবেস তৈরি করার জন্য use <database_name> কমান্ড ব্যবহার করা হয়।

    use myDatabase
    
  2. Collection তৈরি করা: MongoDB তে কলেকশন তৈরি করার জন্য কোনো সরাসরি কমান্ড দরকার হয় না। আপনি যখন ডেটা ইনসার্ট করবেন, তখন MongoDB নিজেই সেই কলেকশন তৈরি করবে।

    db.myCollection.insertOne({ name: "John", age: 30 })
    

    এই কমান্ডটি কলেকশন myCollection তৈরি করবে (যদি এটি আগে না থাকে), এবং এতে একটি ডকুমেন্ট ইনসার্ট করবে।

  3. Collection তালিকা দেখানো: MongoDB তে ডেটাবেসের সমস্ত কলেকশন দেখতে:

    show collections
    

2. Schema Design

MongoDB স্কিমা-লেস ডেটাবেস, যার মানে হল যে আপনি যে ডেটার কাঠামো চান তা ইচ্ছামত পরিবর্তন করতে পারেন। তবে, কিছু সাধারণ নিয়ম এবং ডিজাইন প্যাটার্ন অনুসরণ করা MongoDB তে কার্যকরী ডেটাবেস তৈরি করার জন্য গুরুত্বপূর্ণ।

Schema Design এর মূল ধারণা:

MongoDB তে Schema Design বেশ কিছু দিক অনুসরণ করতে হবে:

  1. ডকুমেন্ট স্টোরেজ: MongoDB তে ডেটা ডকুমেন্ট আকারে সংরক্ষিত থাকে। একটি ডকুমেন্ট হচ্ছে JSON স্ট্রাকচার, যা কীগুচ্ছ (key-value pairs) ধারণ করে। উদাহরণস্বরূপ, একটি ব্যবহারকারীর ডেটা ডকুমেন্ট হিসেবে সংরক্ষণ করা:

    {
      "name": "John Doe",
      "email": "john.doe@example.com",
      "age": 30,
      "address": {
        "street": "123 Main St",
        "city": "New York",
        "state": "NY"
      }
    }
    
  2. ডকুমেন্টের মধ্যে সাব-ডকুমেন্ট: MongoDB তে একটি ডকুমেন্টের মধ্যে অন্য ডকুমেন্ট বা সাব-ডকুমেন্ট রাখতে পারেন। এটি অনেকটা রিলেশনাল ডেটাবেসে JOIN এর কাজ করে। এই নকশা সহজতর এবং দ্রুত অ্যাক্সেস প্রদান করে।

    উদাহরণ:

    {
      "_id": 1,
      "name": "Alice",
      "orders": [
        {
          "order_id": 101,
          "product": "Laptop",
          "price": 1000
        },
        {
          "order_id": 102,
          "product": "Phone",
          "price": 600
        }
      ]
    }
    
  3. টিপিকাল কলেকশন ডিজাইন: MongoDB তে Collection ডিজাইনের সময় বিভিন্ন ধরণের নকশা এবং প্যাটার্ন অনুসরণ করা যেতে পারে। MongoDB এ সাধারণত দুটি প্রধান ডিজাইন প্যাটার্ন ব্যবহার করা হয়:

    • ডকুমেন্ট নরমালাইজেশন (Normalization): যেখানে একাধিক সম্পর্কিত ডেটা আলাদা আলাদা কলেকশনে রাখা হয়। এটি রিলেশনাল ডেটাবেসের মতো কাজ করে। উদাহরণ: users এবং orders আলাদা কলেকশনে রাখা।
    • ডকুমেন্ট ডেনORMALIZATION (Denormalization): যেখানে সম্পর্কিত ডেটা একক ডকুমেন্টে রাখা হয়, যা দ্রুত রিড অপারেশনের জন্য উপকারী। উদাহরণ: একজন ব্যবহারকারীর সমস্ত অর্ডার ডেটা একটিই ডকুমেন্টে সংরক্ষণ করা।

    ডেনরমালাইজেশন উদাহরণ:

    {
      "_id": 1,
      "name": "Alice",
      "orders": [
        {
          "order_id": 101,
          "product": "Laptop",
          "price": 1000
        },
        {
          "order_id": 102,
          "product": "Phone",
          "price": 600
        }
      ]
    }
    
  4. ইনডেক্সিং: MongoDB তে ডেটা দ্রুত অনুসন্ধানের জন্য ইনডেক্স তৈরি করা হয়। MongoDB তে ডিফল্ট _id ফিল্ডের উপর একটি ইনডেক্স তৈরি থাকে, তবে আপনি আপনার প্রয়োজন অনুযায়ী অন্য ফিল্ডের উপরও ইনডেক্স তৈরি করতে পারেন।

    উদাহরণ:

    db.myCollection.createIndex({ "name": 1 })
    
  5. টেক্সট সার্চ: MongoDB তে টেক্সট সার্চ চালানোর জন্য আপনি বিশেষ টেক্সট ইনডেক্স ব্যবহার করতে পারেন, যা দ্রুত টেক্সট অনুসন্ধান করতে সাহায্য করে।

    উদাহরণ:

    db.myCollection.createIndex({ "description": "text" })
    db.myCollection.find({ $text: { $search: "laptop" } })
    

3. ডেটাবেস ডিজাইন প্যাটার্ন

MongoDB ডেটাবেস ডিজাইনে দুটি প্রধান প্যাটার্ন আছে:

  1. এম্বেডেড ডকুমেন্ট (Embedded Documents): MongoDB তে, আপনি সম্পর্কিত ডেটা একসাথে রাখতে পারেন। উদাহরণস্বরূপ, একটি ব্লগ পোস্টের সাথে তার মন্তব্যগুলো একসাথে একটি ডকুমেন্টে রাখা যেতে পারে।

    {
      "_id": 1,
      "title": "MongoDB Tutorial",
      "comments": [
        {
          "user": "John",
          "comment": "Great post!",
          "date": "2024-11-10"
        },
        {
          "user": "Alice",
          "comment": "Thanks for the explanation!",
          "date": "2024-11-11"
        }
      ]
    }
    
  2. রেফারেন্সিং (Referencing): ডেটা পৃথক কলেকশনে রাখা হয় এবং একটি ডকুমেন্ট অন্য ডকুমেন্টের ID ব্যবহার করে তার সাথে সম্পর্কিত হয়। এটি বড় ডেটাসেট এবং নির্দিষ্ট সম্পর্কের ক্ষেত্রে উপকারী।

    {
      "_id": 1,
      "name": "John Doe",
      "address_id": 12345
    }
    
    // Separate collection for addresses
    {
      "_id": 12345,
      "street": "123 Main St",
      "city": "New York",
      "state": "NY"
    }
    

সারাংশ

MongoDB তে ডেটা সংরক্ষণের জন্য Collection তৈরি করা হয় এবং ডেটার কাঠামো (Schema) যথাযথভাবে ডিজাইন করা গুরুত্বপূর্ণ। MongoDB তে স্কিমা-লেস ডেটাবেস মডেল থাকলেও, সঠিক ডিজাইন প্যাটার্ন এবং ডেটার গঠন ভাল পারফরম্যান্স নিশ্চিত করে। ডকুমেন্ট-ভিত্তিক ডিজাইন MongoDB ডেটাবেসে সম্পর্কিত ডেটা সহজে সংরক্ষণ, রিড এবং প্রসেস করতে সাহায্য করে। MongoDB তে ডেনরমালাইজেশন এবং ইনডেক্সিং ডেটার পারফরম্যান্স উন্নত করে এবং দ্রুত অনুসন্ধান করতে সহায়তা করে।

Content added By
Promotion

Are you sure to start over?

Loading...