Horizontal এবং Vertical Partitioning

PHPMyAdmin: Table Partitioning এবং Sharding - পিএইচপি মাইএডমিন (PHP MyAdmin) - Database Tutorials

350

Partitioning হলো একটি ডেটাবেসের বড় টেবিলকে ছোট ছোট ভাগে বিভক্ত করার প্রক্রিয়া, যা ডেটাবেসের কর্মক্ষমতা এবং পরিচালনা সহজ করে। Partitioning এর দুটি প্রধান ধরণ হলো Horizontal Partitioning এবং Vertical Partitioning। এই পদ্ধতিগুলো বড় ডেটাবেস ম্যানেজমেন্ট সিস্টেমে ডেটা সংগঠিত করার জন্য গুরুত্বপূর্ণ।


Horizontal Partitioning (Horizontally Dividing Data)

Horizontal Partitioning-এ টেবিলের ডেটা সারি (row) অনুযায়ী বিভক্ত করা হয়। প্রতিটি অংশ একই সংখ্যক কলাম থাকে, তবে সারিগুলো আলাদা আলাদা থাকে। এটি ডেটাবেসের আকার কমাতে এবং নির্দিষ্ট ডেটার উপর দ্রুত অ্যাক্সেস পেতে সাহায্য করে।

উদাহরণ:

ধরা যাক, একটি টেবিলে ১০,০০০ জন ব্যবহারকারীর ডেটা রয়েছে। Horizontal Partitioning করে এটি দুই ভাগে বিভক্ত করা হলো:

  • Partition 1: যেখানে user_id <= 5000
  • Partition 2: যেখানে user_id > 5000

বৈশিষ্ট্য:

  • সারিগুলি শারীরিকভাবে বিভক্ত করা হয়।
  • ডেটা সাধারণত ডিস্ট্রিবিউটেড সার্ভারে থাকে।
  • বড় ডেটা সেট পরিচালনার জন্য কার্যকর।

সুবিধা:

  1. ল্যাটেন্সি হ্রাস: নির্দিষ্ট পার্টিশনে ডেটা খোঁজার সময় কম লাগে।
  2. লোড ব্যালেন্সিং: প্রতিটি পার্টিশন পৃথক সার্ভারে রাখতে পারলে লোড কমে।
  3. স্কেলিবিলিটি: বড় ডেটাবেস ছোট অংশে বিভক্ত হওয়ায় সহজে পরিচালনা করা যায়।

সীমাবদ্ধতা:

  • ডেটা স্থানান্তরের সময় জটিলতা।
  • Partitioning পলিসি সঠিকভাবে না করলে পারফরম্যান্স খারাপ হতে পারে।

Vertical Partitioning (Vertically Dividing Data)

Vertical Partitioning-এ টেবিলের ডেটা কলাম (column) অনুযায়ী বিভক্ত করা হয়। একটি টেবিলের কলামগুলো বিভিন্ন ভাগে বিভক্ত করে একাধিক টেবিল তৈরি করা হয়। এটি নির্দিষ্ট ডেটা বা কলামের উপর দ্রুত অ্যাক্সেস পেতে সহায়তা করে।

উদাহরণ:

ধরা যাক, একটি users টেবিলে নিচের কলামগুলো আছে:

  • user_id, name, email, address, phone

Vertical Partitioning করে এটি দুই ভাগে বিভক্ত করা হলো:

  • Partition 1: user_id, name, email
  • Partition 2: user_id, address, phone

বৈশিষ্ট্য:

  • প্রতিটি টেবিল একটি নির্দিষ্ট কলাম সেট ধারণ করে।
  • Primary Key বা Foreign Key সম্পর্কিত হতে পারে।

সুবিধা:

  1. ডেটার সুরক্ষা: সংবেদনশীল ডেটা একটি পৃথক টেবিলে রাখা যায়।
  2. পারফরম্যান্স বৃদ্ধি: নির্দিষ্ট কলাম অ্যাক্সেসের জন্য সময় কম লাগে।
  3. স্টোরেজ অপটিমাইজেশন: প্রয়োজনীয় ডেটা অনুযায়ী স্টোরেজ ব্যবহার করা যায়।

সীমাবদ্ধতা:

  • যোগসূত্র বজায় রাখতে অতিরিক্ত জটিলতা।
  • বিভিন্ন টেবিল থেকে ডেটা একত্র করার জন্য অতিরিক্ত কোয়েরি প্রয়োজন।

তুলনা: Horizontal Partitioning বনাম Vertical Partitioning

বৈশিষ্ট্যHorizontal PartitioningVertical Partitioning
ডেটা বিভক্তির ধরণসারি (Row) অনুযায়ী বিভক্তকলাম (Column) অনুযায়ী বিভক্ত
পারফরম্যান্সনির্দিষ্ট সারির উপর দ্রুত অ্যাক্সেসনির্দিষ্ট কলামের উপর দ্রুত অ্যাক্সেস
স্টোরেজসারি অনুযায়ী স্থান ভাগ করে নেয়কলাম অনুযায়ী স্থান ভাগ করে নেয়
স্কেলিবিলিটিবড় ডেটা সেটের জন্য কার্যকরছোট ডেটাবেসের জন্য কার্যকর
উদাহরণuser_id <= 5000 এবং > 5000user_id, name বনাম phone
ডেটা পুনরুদ্ধার জটিলতাকমতুলনামূলক বেশি

কখন Horizontal বা Vertical Partitioning ব্যবহার করবেন?

Horizontal Partitioning:

  • বড় আকারের ডেটাবেসে যেখানে সারি সংখ্যা অনেক।
  • ডেটা বিভিন্ন সার্ভারে বিভক্ত করতে চাইলে।
  • ভৌগোলিকভাবে বিতরণকৃত সিস্টেমে।

Vertical Partitioning:

  • যখন টেবিলের নির্দিষ্ট কলাম অনেক বেশি জায়গা নেয়।
  • সংবেদনশীল ডেটাকে আলাদা রাখতে।
  • ছোট বা মধ্যম আকারের ডেটাবেসে।

সারাংশ

Horizontal Partitioning এবং Vertical Partitioning ডেটাবেস ব্যবস্থাপনাকে সহজ এবং দ্রুত করার জন্য গুরুত্বপূর্ণ কৌশল। Horizontal Partitioning সারি অনুযায়ী ডেটা ভাগ করে বড় ডেটা সেট পরিচালনা সহজ করে, যেখানে Vertical Partitioning কলাম অনুযায়ী ডেটা ভাগ করে নির্দিষ্ট ডেটার উপর দ্রুত অ্যাক্সেস নিশ্চিত করে। প্রয়োগের ক্ষেত্রে প্রয়োজন এবং ডেটাবেসের কাঠামো বিবেচনা করে সঠিক পদ্ধতি নির্বাচন করা উচিত।

Content added By
Promotion

Are you sure to start over?

Loading...