ArangoDB Collections

Database Tutorials - আরাঙ্গো (ArangoDB)
252
252

ArangoDB Collections হল ডাটাবেসের একটি গুরুত্বপূর্ণ উপাদান যা ডেটা সঞ্চয় এবং পরিচালনা করতে ব্যবহৃত হয়। ArangoDB-তে, একটি Collection মূলত ডেটা সংরক্ষণের একটি কন্টেইনার, যেখানে ডকুমেন্ট বা এজ ডেটা মডেল সঞ্চিত হয়।

ArangoDB Collections ডেটার কাঠামো এবং অ্যাক্সেসের পদ্ধতি নির্ধারণ করতে সাহায্য করে। এটি ডকুমেন্ট বা গ্রাফ ডেটাবেসের বিভিন্ন প্রয়োজনীয়তার জন্য আলাদাভাবে কনফিগার করা যায়।


Collections এর ধরন

ArangoDB-তে দুটি প্রাথমিক ধরণের Collection রয়েছে:

Document Collection

  • এটি সাধারণ ডকুমেন্ট স্টোরেজের জন্য ব্যবহৃত হয়।
  • প্রতিটি ডকুমেন্ট একটি JSON অবজেক্ট হিসেবে সঞ্চিত থাকে।
  • ডকুমেন্টগুলোর মধ্যে সম্পর্ক নির্ধারণের প্রয়োজন নেই।

Edge Collection

  • এটি গ্রাফ ডেটা মডেলের জন্য ব্যবহৃত হয়।
  • ডকুমেন্টগুলো Edge হিসেবে কাজ করে, যা গ্রাফের মধ্যে Vertex বা নোডগুলোর মধ্যে সম্পর্ক সংজ্ঞায়িত করে।
  • গ্রাফ ট্রাভার্সাল এবং সম্পর্কিত ডেটা পরিচালনার জন্য এটি গুরুত্বপূর্ণ।

Collection তৈরি এবং ম্যানেজমেন্ট

ArangoDB-তে Collection তৈরি করা এবং পরিচালনা করা অত্যন্ত সহজ। নিচে কিছু প্রক্রিয়া তুলে ধরা হলো:

১. Collection তৈরি করা

Collection তৈরি করার জন্য ArangoDB Web Interface, AQL, বা API ব্যবহার করা যায়।

AQL দিয়ে Collection তৈরি:
CREATE COLLECTION myCollection
Web Interface দিয়ে:
  1. ArangoDB Web Interface-এ লগইন করুন।
  2. ডাটাবেস নির্বাচন করুন।
  3. "Create Collection" ক্লিক করুন এবং Collection-এর নাম দিন।
  4. Document বা Edge Collection নির্বাচন করুন।

২. Collection Schema কনফিগারেশন

  • Collection-এ ডেটার জন্য স্কিমা নির্ধারণ করা যায়।
  • ডেটা ভ্যালিডেশনের জন্য প্রয়োজনীয় নিয়মাবলী ব্যবহার করা হয়।

৩. Collection ম্যানেজমেন্ট

  • Update: Collections এর স্ট্রাকচার পরিবর্তন।
  • Delete: অনাকাঙ্ক্ষিত Collections মুছে ফেলা।
  • Rename: Collections পুনঃনামকরণ।

Data Validation

ArangoDB Collections ডেটা ভ্যালিডেশনের জন্য স্কিমা নির্ধারণ করতে দেয়, যা ডেটার মান নিশ্চিত করে।

উদাহরণ:

{
  "rule": {
    "type": "object",
    "properties": {
      "name": { "type": "string" },
      "age": { "type": "number" }
    },
    "required": ["name", "age"]
  },
  "level": "strict",
  "message": "Invalid data format."
}

Collections এর সুবিধা

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

সারাংশ

ArangoDB Collections ডেটা সঞ্চয় এবং পরিচালনার একটি মৌলিক উপাদান। এটি ডকুমেন্ট এবং এজ উভয় ধরনের ডেটা সমর্থন করে। Collections-এর মাধ্যমে ডেটার কাঠামো, স্কিমা, এবং সম্পর্ক নির্ধারণ সহজ এবং কার্যকর হয়। ArangoDB Collections ডেভেলপারদের জন্য ডেটা মডেলিং এবং অ্যাপ্লিকেশন উন্নয়নের প্রক্রিয়া আরও সুবিধাজনক করে তোলে।

common.content_added_by

Collections এর ধরন (Document এবং Edge)

222
222

ArangoDB Collections হলো এমন ডেটা স্টোরেজ ইউনিট, যেখানে ডেটা সংরক্ষণ এবং পরিচালনা করা হয়। ArangoDB-তে প্রধানত দুই ধরনের Collections রয়েছে: Document Collection এবং Edge Collection। এরা প্রতিটির নিজস্ব ব্যবহার এবং বৈশিষ্ট্য রয়েছে।


Document Collection

Document Collection হলো JSON ফরম্যাটে ডেটা সংরক্ষণের একটি ডেটা স্টোরেজ। এটি ডকুমেন্ট ভিত্তিক ডেটাবেস মডেল ব্যবহার করে এবং মূলত ডাটা ইন্টিগ্রিটির উপর জোর দেয়।

বৈশিষ্ট্য:

  • JSON ডকুমেন্ট ফরম্যাটে ডেটা সংরক্ষণ করে।
  • প্রতিটি ডকুমেন্ট একটি ইউনিক Key দ্বারা শনাক্ত হয়।
  • CRUD (Create, Read, Update, Delete) অপারেশন সহজে সম্পাদন করা যায়।

ব্যবহার:

  • সাধারণ ডেটাবেসের জন্য।
  • যেমন: ব্যবহারকারীর প্রোফাইল, পণ্য ডেটা, বা লেনদেনের রেকর্ড।

উদাহরণ:

{
  "_key": "user123",
  "name": "John Doe",
  "email": "john.doe@example.com",
  "age": 29
}

Edge Collection

Edge Collection মূলত গ্রাফ ডেটাবেসে ব্যবহৃত হয় এবং এটি Vertex বা Node এর মধ্যে সম্পর্ক নির্দেশ করে। প্রতিটি Edge একটি from এবং to ফিল্ড দ্বারা সংযুক্ত থাকে।

বৈশিষ্ট্য:

  • Vertex বা Node এর মধ্যে সংযোগ স্থাপন করে।
  • প্রতিটি Edge এর from এবং to ফিল্ড থাকে, যা Vertex এর মধ্যে সম্পর্ক নির্দেশ করে।
  • Directed এবং Undirected গ্রাফ সমর্থন করে।

ব্যবহার:

  • সম্পর্কিত ডেটা মডেলিংয়ের জন্য।
  • যেমন: সোশ্যাল নেটওয়ার্কের বন্ধুত্ব সম্পর্ক, রাস্তার নেটওয়ার্ক, বা প্রোডাক্ট রিকমেন্ডেশন।

উদাহরণ:

{
  "_key": "edge123",
  "_from": "users/user123",
  "_to": "users/user456",
  "relation": "friend"
}

Document এবং Edge Collection এর পার্থক্য

বৈশিষ্ট্যDocument CollectionEdge Collection
মূল ধারণাJSON ডকুমেন্ট সংরক্ষণ।Vertex বা Node এর মধ্যে সম্পর্ক সংরক্ষণ।
ব্যবহারসাধারণ ডেটাবেস অপারেশন।গ্রাফ ডেটাবেস সম্পর্ক মডেলিং।
ডেটার ধরনস্বাধীন ডকুমেন্ট।Directed বা Undirected Edge।
কোয়েরি অপারেশনCRUD অপারেশন।Graph Traversal অপারেশন।

Collections এর ব্যবহার ক্ষেত্র

  • Document Collection:
    ব্যবহারকারীর প্রোফাইল, পণ্য ইনভেন্টরি, লেনদেনের ডেটা।
  • Edge Collection:
    সোশ্যাল নেটওয়ার্ক, লজিস্টিক নেটওয়ার্ক, বা রাস্তার মানচিত্র।

সারাংশ

ArangoDB Collections ডেটা মডেলিংয়ের জন্য একটি গুরুত্বপূর্ণ ফিচার। Document Collection সাধারণ ডেটা সংরক্ষণে ব্যবহৃত হয়, আর Edge Collection জটিল সম্পর্ক এবং গ্রাফ ডেটা মডেল তৈরি করতে ব্যবহৃত হয়। এই বৈশিষ্ট্যগুলি ArangoDB-কে একটি শক্তিশালী মাল্টি-মডেল ডেটাবেস সিস্টেম হিসেবে গড়ে তোলে।

common.content_added_by

Collection তৈরি এবং ম্যানেজমেন্ট

216
216

Collection হলো ArangoDB-তে ডেটা সংরক্ষণের একটি মৌলিক ইউনিট। এটি ডেটাবেসে ডকুমেন্ট বা এজ (গ্রাফ ডেটার জন্য) সংরক্ষণের জন্য ব্যবহৃত হয়। ArangoDB-তে Collections তৈরি ও ম্যানেজ করা সহজ এবং এর মাধ্যমে ডেটার কার্যকরী ম্যানেজমেন্ট সম্ভব।


Collection এর ধরন

  1. Document Collection
    • JSON ফরম্যাটে ডকুমেন্ট সংরক্ষণ করে।
    • Non-relational এবং Hierarchical ডেটা মডেলিং এর জন্য উপযুক্ত।
  2. Edge Collection
    • গ্রাফ ডেটার জন্য ব্যবহার হয়।
    • Vertex এবং Edge এর মধ্যে সম্পর্ক সংরক্ষণ করে।

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

Web Interface দিয়ে Collection তৈরি

  1. Step 1: ArangoDB Web Interface-এ লগইন করুন।
  2. Step 2: আপনার ডাটাবেস সিলেক্ট করুন।
  3. Step 3: "Collections" ট্যাবে ক্লিক করুন।
  4. Step 4: "Create Collection" বাটনে ক্লিক করুন।
  5. Step 5: Collection এর নাম লিখুন এবং এর ধরন সিলেক্ট করুন (Document/Edge)।
  6. Step 6: প্রয়োজন অনুযায়ী Replication Factor, Shard Keys, এবং Schema Validation কনফিগার করুন।
  7. Step 7: "Create" বাটনে ক্লিক করুন।

AQL দিয়ে Collection তৈরি

CREATE COLLECTION myCollection TYPE document
  • TYPE document: এটি Document Collection তৈরি করে।
  • TYPE edge: এটি Edge Collection তৈরি করে।

ArangoShell দিয়ে Collection তৈরি

db._create("myCollection");

Collection ম্যানেজমেন্ট

ডকুমেন্ট যোগ করা

db.myCollection.insert({
  name: "John Doe",
  age: 30,
  city: "Dhaka"
});

ডকুমেন্ট আপডেট করা

db.myCollection.update("documentKey", {
  age: 31
});

ডকুমেন্ট মুছে ফেলা

db.myCollection.remove("documentKey");

Collection Schema কনফিগার করা

  • Schema ব্যবহার করে ডেটার কাঠামো নির্ধারণ করা যায়।
  • Example:
db._create("myCollection", {
  schema: {
    rule: {
      type: "object",
      properties: {
        name: { type: "string" },
        age: { type: "integer" }
      },
      required: ["name", "age"]
    }
  }
});

Collection ম্যানেজমেন্ট টুলস

  1. Web Interface: Collection তৈরি, ডেটা দেখা এবং ম্যানেজ করার জন্য একটি সহজ UI।
  2. ArangoShell: কমান্ড-লাইন ইন্টারফেস ব্যবহার করে দ্রুত অপারেশন।
  3. AQL: কোয়েরি চালিয়ে Collection এবং ডেটা পরিচালনা।

উপকারিতা

  • ডেটা স্ট্রাকচার নিয়ন্ত্রণ: Schema Validation ব্যবহার করে ডেটার মান নিশ্চিত করা।
  • সহজ ডেটা ম্যানিপুলেশন: ডকুমেন্ট যোগ, মুছে ফেলা এবং আপডেট সহজ।
  • স্কেলেবিলিটি: বড় ডেটাবেস পরিচালনার জন্য উপযুক্ত।

সারাংশ

ArangoDB-তে Collection তৈরি এবং ম্যানেজমেন্ট অত্যন্ত সহজ এবং কার্যকর। এর মাধ্যমে ডেটার কাঠামো নির্ধারণ এবং ম্যানেজমেন্ট প্রক্রিয়া সহজ হয়। ডেভেলপাররা Web Interface, ArangoShell, এবং AQL ব্যবহার করে Collection পরিচালনার সর্বোচ্চ সুবিধা নিতে পারেন।

common.content_added_by

Collection Schema কনফিগারেশন

224
224

Collection Schema কনফিগারেশন ArangoDB-তে ডেটা ভ্যালিডেশনের জন্য ব্যবহৃত হয়। এটি নিশ্চিত করে যে কোনো ডকুমেন্ট বা ডেটা কালেকশনে যোগ করার আগে নির্ধারিত নিয়ম বা স্কিমা মেনে চলছে। স্কিমা কনফিগারেশন আপনাকে ডেটার গুণগত মান ধরে রাখতে এবং ভুল ডেটা এন্ট্রি প্রতিরোধ করতে সাহায্য করে।


স্কিমা কনফিগারেশনের মূল ধারণা

ArangoDB-তে JSON Schema ব্যবহার করে স্কিমা কনফিগার করা হয়। এর মাধ্যমে আপনি ডেটার টাইপ, কাঠামো, এবং অন্যান্য ভ্যালিডেশন নিয়ম নির্ধারণ করতে পারেন।

  • Schema Rule: ডেটার কাঠামো সংজ্ঞায়িত করে।
  • Validation Level: ডেটার ভ্যালিডেশন কতটা কঠোর হবে তা নির্ধারণ করে।

স্কিমা কনফিগারেশনের উপাদানসমূহ

১. Rule

Rule নির্ধারণ করে ডকুমেন্টের কাঠামো এবং ডেটা টাইপ। উদাহরণস্বরূপ:

  • type: ডেটার ধরন (যেমন string, number)।
  • properties: ডকুমেন্টের ফিল্ড এবং তাদের প্রয়োজনীয়তা।
  • required: কোন ফিল্ডগুলো বাধ্যতামূলক।

২. Level

Level ডেটার ভ্যালিডেশনের কঠোরতা নির্ধারণ করে:

  • none: কোনো ভ্যালিডেশন হবে না।
  • new: কেবল নতুন ডকুমেন্টের জন্য ভ্যালিডেশন হবে।
  • strict: নতুন এবং আপডেট করা ডকুমেন্ট উভয়ের জন্য ভ্যালিডেশন প্রযোজ্য।

৩. Message

কাস্টম ভ্যালিডেশন ত্রুটি বার্তা যোগ করতে ব্যবহৃত হয়।


স্কিমা কনফিগার করার উদাহরণ

নিচের উদাহরণে একটি কালেকশন তৈরি করা হয়েছে যেখানে ডকুমেন্টের name ফিল্ড একটি স্ট্রিং হতে হবে এবং age একটি নম্বর হতে হবে।

db._create("MyCollection", {
  schema: {
    rule: {
      type: "object",
      properties: {
        name: { type: "string" },
        age: { type: "number" },
      },
      required: ["name", "age"],
      additionalProperties: false, // অপ্রত্যাশিত ফিল্ড নিষিদ্ধ।
    },
    level: "strict", // নতুন এবং আপডেট ডেটার জন্য কঠোর ভ্যালিডেশন।
    message: "Invalid data format!", // ত্রুটি বার্তা।
  },
});

স্কিমা আপডেট করার পদ্ধতি

ইতোমধ্যে তৈরি করা কালেকশনের স্কিমা আপডেট করতে:

db._collection("MyCollection").properties({
  schema: {
    rule: {
      type: "object",
      properties: {
        title: { type: "string" },
        description: { type: "string" },
      },
      required: ["title"],
      additionalProperties: true,
    },
    level: "new",
  },
});

স্কিমা ভ্যালিডেশনের উদাহরণ

সঠিক ডকুমেন্ট:

db.MyCollection.save({ name: "John", age: 30 });

ভুল ডকুমেন্ট (ত্রুটি বার্তা পাবেন):

db.MyCollection.save({ name: 123, age: "thirty" });

সারাংশ

ArangoDB-এর Collection Schema ডেটা মডেলিং এবং ভ্যালিডেশন আরও নির্ভুল ও নিরাপদ করে। এটি ডকুমেন্টের কাঠামো, টাইপ, এবং প্রয়োজনীয় ফিল্ড নির্ধারণ করতে সাহায্য করে। কঠোর ভ্যালিডেশন দিয়ে আপনি ডেটার মান নিয়ন্ত্রণ করতে পারেন এবং ভুল ডেটা সংরক্ষণ প্রতিরোধ করতে পারেন।

common.content_added_by

Data Validation

262
262

Data Validation হল ডাটার সঠিকতা, সামঞ্জস্যতা এবং গুণগত মান নিশ্চিত করার একটি প্রক্রিয়া। ArangoDB-তে ডেটা ভ্যালিডেশন মূলত Collections-এর সাথে সম্পর্কিত, যেখানে একটি Schema কনফিগার করা হয় ডেটার নির্দিষ্ট গঠন এবং নিয়ম নির্ধারণের জন্য। এটি ডেটা ইনসার্ট এবং আপডেট করার সময় সঠিক ডেটা নিশ্চিত করে।


Data Validation এর বৈশিষ্ট্য

  1. Schema Validation:
    ArangoDB Collections-এ JSON Schema ব্যবহার করে ডেটা ভ্যালিডেশনের নিয়ম নির্ধারণ করা যায়।
  2. Flexible Rules:
    ডেটা ফিল্ডের টাইপ, ফিল্ডের উপস্থিতি বা নির্দিষ্ট মান নিশ্চিত করা যায়।
  3. Automatic Enforcement:
    ইনসার্ট এবং আপডেটের সময় ডেটা ভ্যালিডেশন স্বয়ংক্রিয়ভাবে প্রয়োগ হয়।
  4. Error Reporting:
    ডেটা ভ্যালিডেশন ব্যর্থ হলে স্পষ্ট ত্রুটি বার্তা প্রদান করে।

Schema কনফিগারেশন

Schema Example

নিচের উদাহরণে একটি Collection-এর Schema কনফিগার করা হয়েছে:

{
  "rule": {
    "type": "object",
    "properties": {
      "name": { "type": "string" },
      "age": { "type": "integer", "minimum": 18 },
      "email": { "type": "string", "format": "email" }
    },
    "required": ["name", "age"]
  },
  "level": "strict",
  "message": "Data validation failed!"
}

উপাদান ব্যাখ্যা

  • type: ডেটার টাইপ নির্ধারণ (যেমন: string, integer)।
  • properties: ফিল্ডগুলোর ভ্যালিডেশন নিয়ম।
  • required: বাধ্যতামূলক ফিল্ডের তালিকা।
  • level: ভ্যালিডেশনের স্তর, যেমন strict, moderate, বা none
  • message: ভ্যালিডেশন ব্যর্থ হলে দেখানো বার্তা।

Schema প্রয়োগ করা

Collection তৈরি করার সময় Schema যুক্ত করা

db._create("my_collection", {
  schema: {
    rule: {
      "type": "object",
      "properties": {
        "name": { "type": "string" },
        "age": { "type": "integer", "minimum": 18 }
      },
      "required": ["name", "age"]
    },
    level: "strict",
    message: "Invalid data!"
  }
});

Schema আপডেট করা

ইতিমধ্যে তৈরি করা Collection-এ Schema আপডেট করতে:

db._collection("my_collection").properties({
  schema: {
    rule: {
      "type": "object",
      "properties": {
        "name": { "type": "string" },
        "age": { "type": "integer", "minimum": 18 },
        "email": { "type": "string", "format": "email" }
      },
      "required": ["name", "age"]
    },
    level: "moderate",
    message: "Validation error!"
  }
});

Validation Level

  1. Strict:
    যদি ডেটা ভ্যালিড না হয়, তাহলে এটি গ্রহণ করা হবে না।
  2. Moderate:
    ভ্যালিডেশন ব্যর্থ হলেও ডেটা গ্রহণ করা হবে তবে সতর্কতা দেখানো হবে।
  3. None:
    ভ্যালিডেশন নিষ্ক্রিয় থাকবে।

Error Handling

ডেটা ইনসার্ট বা আপডেট করার সময় ভ্যালিডেশন ব্যর্থ হলে ArangoDB একটি ত্রুটি বার্তা প্রদান করে।
উদাহরণ:

{
  "error": true,
  "code": 400,
  "errorMessage": "Validation error!"
}

Data Validation এর সুবিধা

  1. ডেটার সঠিকতা নিশ্চিত করা।
  2. ত্রুটিপূর্ণ ডেটা প্রতিরোধ করা।
  3. ডাটাবেসে গুণগত মান বজায় রাখা।
  4. বিজনেস লজিকের সাথে সামঞ্জস্যপূর্ণ ডেটা সংরক্ষণ।

সারাংশ

ArangoDB-তে Data Validation একটি শক্তিশালী টুল যা ডেটার গুণমান এবং সঠিকতা নিশ্চিত করতে সহায়ক। এটি JSON Schema-র মাধ্যমে নিয়ম সংজ্ঞায়িত করে এবং স্বয়ংক্রিয়ভাবে ডেটা ভ্যালিডেশন সম্পন্ন করে। ডেভেলপাররা এই বৈশিষ্ট্যটি ব্যবহার করে আরও নির্ভরযোগ্য এবং কার্যকর ডাটাবেস তৈরি করতে পারেন।

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

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

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

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