এক্সেস টেবিল রিলেশন করা । এক্সেস ২০১৬ বাংলা টিউটোরিয়াল – পর্ব ৮

এক্সেস টেবিল রিলেশন করার বিভিন্ন পদ্ধতি

ডাটা ম্যানেজমেন্টের ক্ষেত্রে এক্সেস টেবিল রিলেশন করা অত্যাবশ্যক। একটি ডেটাবেজে একাধিক টেবিল থাকতেই পারে। আর দুটি টেবিলের কমন ফিল্ডের উপর ভিত্তি করে সম্পর্ক স্থাপন করাকেই রিলেশনশিপ বলে। যে ডেটাবেজের টেবিলের মধ্যে রিলেশন থাকে সে ডেটাবেজকে রিলেশনাল ডেটাবেজ বলা হয়। রিলেশনকৃত টেবিলের মধ্যে থেকে খুব সহজে ডেটা ব্যবস্থাপনার কাজ সম্পাদন করা যায়।

অর্থাৎ ডেটাবেজকে ভেঙ্গে একাধিক ডেটা টেবিল তৈরি করে রিলেশনশিপের মাধ্যমে ডেটা নিয়ে কাজ করা যায়। ১৯৬৯ সালে Edgar Frank Codd সর্বপ্রথম রিলেশনশিপ পদ্ধতি প্রবর্তন করেন। Edgar Frank Codd ১৯ আগস্ট ১৯২৩ সালে Fortuneswell, Dorset, England এ জন্মগ্রহণ করেন এবং ১৮ এপ্রিল ২০০৩ সালে Florida, USA মৃত্যুবরণ করেন।

টেবিলদ্বয়ের ভিতর রিলেশন তৈরি করার শর্ত

দুটি টেবিলের মধ্যে রিলেশনশিপ তৈরি করতে হলে নূন্যতম নিচের শর্তগুলো পূরণ করতে হবে:

  • টেবিল দুটির মধ্যে নূন্যতম একটি কমন ফিল্ড থাকতে হবে। কমন ফিল্ডের নাম ও ডেটা টাইপ এবং ফিল্ড সাইজ একই থাকতে হবে।
  • যে কোন একটি টেবিলের একটি ফিল্ড প্রাইমারি কী দ্বারা সনাক্ত করতে হবে। অর্থাৎ প্রাইমারি কী দ্বারা সনাক্তকৃত ফিল্ডের তথ্য ইউনিক হতে হবে।
  • উভয় টেবিল একই সময় ওপেন করা থাকতে হবে।

টেবিল রিলেশনের প্রকারভেদ

একাধিক ডেটা টেবিলের মধ্যে নিম্নলিখিত ৩টি পদ্ধতিতে রিলেশন তৈরি করা যায়। যথা-

  • One-to-one রিলেশন
  • One-to-many রিলেশন
  • Many-to-many রিলেশন

One-to-one রিলেশন: কোন ডেটাবেজের একটি টেবিলের একটি রেকর্ডের সাথে অন্য টেবিলের শুধুমাত্র একটি রেকর্ডের সাথে সম্পর্ক স্থাপন করা হয়, তাকে One-to-one রিলেশনশিপ বলে। যখন কোন ডেটাবেজকে ভেঙ্গে একাধিক ডেটাটেবিলে সংরক্ষণ করা হয় তখন One-to-one রিলেশন থাকা জরুরী।

ধরুন, কোন প্রতিষ্ঠানের কর্মচারীর নাম, ঠিকানা, পদবি ইত্যাদি একটি ডেটা টেবিলে এবং তাদের বেতন সংক্রান্ত তথ্যাবলি অন্য ডেটা টেবিলে সংরক্ষণ করা যায়। এক্ষেত্রে দুটি ডেটা টেবিলের মধ্যে একটি কমন ফিল্ডের ওপর ভিত্তি করে One-to-one রিলেশনশিপ তৈরি করা হয়।

একটি বিষয় লক্ষ্য রাখতে হবে, এক্ষেত্রে দু‘টি টেবিলের যে ফিল্ডের সাথে রিলেশন তৈরি করতে চান ফিল্ড দু‘টিকে অবশ্যই প্রাইমারি কী দ্বারা ডিফাইন করতে হবে।

হাতে কলমে One-to-one রিলেশন

নিচের মত দু‘টি টেবিল তৈরি করুন।

টেবিলের নাম: Employee Information

Create Table for relation in Access 2016

টেবিলের নাম: Employee Salary

Create Table for relation in Access 2016

  • Database Tools ট্যাব হতে Relationship প্যানেল বা গ্রুপ হতে Relationship ক্লিক করুন।

Select Relationship from database tools

  • এবারে প্রয়োজনীয় টেবিল Add করুন। এক্ষেত্রে আমরা Employee Information ও Employee Salary টেবিল দুটি Add করেছি।

Add Employee information and Employee salary table

লক্ষ্য করুন টেবিল দু‘টির মধ্যে Emp_ID ফিল্ডটি কমন এবং প্রাইমারি কী দ্বারা ডিফাইন করা হয়েছে।

  • এবারে Employee Information টেবিলের Emp_ID ফিল্ডটি ড্রাগ করে Employee Salary টেবিলের Emp_ID ফিল্ডের উপর ছেড়ে দিন।

Drag common field for relationship

  • প্রদর্শিত Edit Relationship এর ডায়ালগ বক্স এর লাল চিহ্নিত স্থানের অপশনগুলি ক্লিক করে Create ক্লিক করুন।

Select create from edit relationship dialogbox

হয়ে গেল One-to-one রিলেশনশিপ। এবারে টেবিল দু‘টির মধ্যে রেকর্ড ইনপুট করুন। সাধারণত টেবিলসমূহের মধ্যে রিলেশনশিপ তৈরি করার পর ডেটা ইনপুট করতে হয়।

One-to-Many রিলেশন: কোন ডেটাবেজের একটি টেবিলের একটি রেকর্ডের সাথে অন্য টেবিলের একাধিক রেকর্ডের সাথে সম্পর্ক স্থাপন করা হয়, তাকে One-to-Many রিলেশনশিপ বলে। টেবিল রিলেশনের ক্ষেত্রে এটি বহুল ব্যবহৃত রিলেশন পদ্ধতি।

ধরুন, কোন প্রতিষ্ঠানে বিভিন্ন সরবরাহকারী বিভিন্ন পণ্য সরবরাহ করে থাকে। এজন্য সরবরাহকারীর বিভিন্ন তথ্য সংরক্ষণের জন্য একটি টেবিল এবং পণ্য সংক্রান্ত তথ্য সংরক্ষণের জন্য একটি টেবিল তৈরি করা আছে।

হাতে কলমে One-to-Many রিলেশন

এজন্য নিচের মত প্রাইমারি কী সম্বলিত দু‘টি টেবিল তৈরি করুন।

টেবিলের নাম: Suppliers Information

Create Suppliers Information in Access 2016

টেবিলের নাম: Suppliers Orders

Create Suppliers Orders table in Access 2016

  • Database Tools ট্যাব হতে Relationship প্যানেল বা গ্রুপ হতে Relationship ক্লিক করুন।
  • এবারে প্রয়োজনীয় টেবিল Add করুন। এক্ষেত্রে আমরা Customer ও Order টেবিল দুটি Add করেছি।

লক্ষ্য করুন টেবিল দু‘টির মধ্যে Cust_ID ফিল্ডটি কমন এবং প্রাইমারি কী দ্বারা ডিফাইন করা হয়েছে। এবারে Customer টেবিলের Emp_ID ফিল্ডটি ড্রাগ করে Order টেবিলের Emp_ID ফিল্ডের উপর ছেড়ে দিন।

One to Many relationship in Access 2016

  • প্রদর্শিত Edit Relation এর ডায়ালগ বক্স হতে শুধুমাত্র Enforce Referential Integrity ক্লিক করে Create ক্রিক করুন।

Create Relationship for one to many in Access 2016

হয়ে গেল One-to-Many রিলেশনশিপ।

হাতে কলমে Many-to-Many রিলেশন

টেবিল তৈরি করার বিভিন্ন পদ্ধতি ৭নং পর্বে বিস্তারিত আলোচনা করা হয়েছে। এবারে রিলেশনশিপ বোঝার জন্য ৩টি টেবিল তৈরি করে তাদের মধ্যে রিলেশনশিপ তৈরি করবো। নিচে ৩টি টেবিলের নাম, ফিল্ডের নাম ও ডেটা ধরণ দেওয়া হলো:

নোট: Field Name এর পাশে (PK) দ্বারা Primary Key বোঝানো হয়েছে। অর্থাৎ ঐ সমস্ত ফিল্ডকে Primary Key দ্বারা ডিফাইন করুন।

টেবিলের নাম: Customers

Field Name Data Type
CustomerID (PK) AutoNumber
CustomerName ShortText
CustomerAddress ShortText
DateCreated Date&Time
CellNumber ShortText

টেবিলের নাম: Products

Field Name Data Type
ProductID (PK) AutoNumber
Product Name ShortText
Price ShortText
Date Created Date&Time

টেবিলের নাম: Orders

Field Name Data Type
OrderID (PK) AutoNumber
CustomerID ShortText
ProductID ShortText
DateCreated Date&Time

তাহলে ঝটপট তৈরি করে ফেলুন উপরের ৩টি টেবিল এবং প্রতিটি টেবিল কিছু রেকর্ড ইনপুট করুন।

এবারে ৩টি টেবিলের মধ্যে রিলেশনশিপ তৈরি করার জন্য নিম্নরূপ পদক্ষেপ গ্রহণ করুন।

  • ট্যাববার হতে Database Tools ট্যাব ক্লিক করুন।
  • Relationships গ্রুপ বা প্যানেল হতে Relationships ক্লিক করুন।
  • কীবোর্ডের Shift কী চেপে ধরে ৩টি টেবিল সিলেক্ট করুন।
  • Add বাটন ক্লিক করুন।
  • Close বাটন ক্লিক করে Show Table ডায়ালগ বক্সটি বন্ধ করুন।

Select table for relationship in Access 2016

লক্ষ্য করুন, সিলেক্টকৃত ৩টি টেবিল Relationships উইন্ডোতে প্রদর্শিত হয়েছে।

Access Relationship Window

এবারে রিলেশন করার পালা।

উপরের চিত্রে লক্ষ্য করুন, Customers এবং Orders দুটি টেবিলের মধ্যে CustomerID নামে একই ফিল্ড নেম ও ডেটা টাইপের ফিল্ড রয়েছে। এছাড়াও Orders এবং Products টেবিলদ্বয়ের মধ্যে ProductID নামে একই ফিল্ড নেম ও ডেটা টাইপের ফিল্ড রয়েছে।

এক্ষেত্রে আমরা Customers এবং Orders দুটি টেবিলের মধ্যে এবং Orders এবং Products টেবিলদ্বয়ের মধ্যে রিশেনশিপ তৈরি করবো।

  • Relationships উইন্ডোতে অবস্থিত Customers টেবিলের CustomerID ফিল্ডটিকে মাউস দ্বারা ড্রাগ করে Orders টেবিলের CustomerID ফিল্ডের উপর ছেড়ে দিন।

Access Relationship window

  • নিচের মত উইন্ডো প্রদর্শিত হবে।

Access Relationship window

  • প্রদর্শিত উইন্ডো হতে Enforce Referential Integrity এর চেকবক্স ক্লিক করে Create বাটন ক্লিক করুন।

দেখুন টেবিল দু‘টির মধ্যে রিলেশন তৈরি হয়ে গেছে এবং একটি বক্র রেখা দ্বারা তা প্রদর্শিত হচ্ছে।

Access Relationship window

  • এবারে উপরের ধাপ অনুসরণ করে Orders এবং Products টেবিলদ্বয়ের মধ্যে ProductID ফিল্ডের মধ্যে রিলেশনশিপ তৈরি করুন।

Access Relationship window

অবশেষে ৩টি টেবিলের মধ্যে ২টি রিলেশনশিপ নিম্নের চিত্রের মতো প্রদর্শিত হবে।

Access Relationship window

রিলেশনশিপ এডিট করা

  • রিলেশনশিপ উইন্ডো ওপেন করুন এবং রিলেশন বারের উপর মাউসের রাইট বাটন ক্লিক করে Edit Relation ক্লিক করুন।

Edit-Relation-in-Access-201

  • এবারে প্রয়োজনীয় অপশন নির্ধারণ করে Ok ক্লিক করুন।

রিলেশনশিপ মুছে ফেলা

  • রিলেশনশিপ উইন্ডো ওপেন করুন।
  • যে রিলেশন ডিলিট করতে চান তার উপর মাউসের রাইট বাটন ক্লিক করে Edit Relation ক্লিক করুন।

Delete-Relationship-in-Acce

  • প্রদর্শিত উইন্ডো হতে Yes ক্লিক করুন।

টেবিল রিলেশনশিপের সুবিধা কি?

যে কোন রিলেশনাল ডেটাবেজ (RDBMS) এর জন্য রিলেশনশিপই হলো মূল ভিত্তি।

ডেটাবেজ ডিজাইন করার জন্য রিলেশনশিপ একটি শক্তিশালি ‍টুলস হিসেবে ব্যবহৃত হয়।

এখানে ডেটাবেজ ডিজাইনের ক্ষেত্রে গুরুত্বপূর্ণ সুবিধাসমূহ বর্ণিত হলো:

  • প্রয়োজনের তুলনায় কম জায়গা লাগে।
  • ডেটা অখণ্ডতা বজায় রাখতে সহায়তা করে থাকে।
  • ব্যবহারকারীদের জন্য ব্যবহারযোগ্যতা বৃদ্ধিতে সহায়তা করে।
  • সহজে ডেটা রক্ষনাবেক্ষণ করা যায়।
  • নিরাপত্তার ক্ষেত্রে সহায়তা করে।
  • ডেটাবেজের কর্মক্ষমতা প্রসারণ বা সম্প্রসারণের ক্ষেত্রে সহায়তা করে থাকে।

প্রাইমারি কী (Primary Key) কি?

একাধিক টেবিলের মধ্যে রিলেশন তৈরি করার জন্য প্রাইমারি কী দ্বারা টেবিলের ফিল্ডকে ডিফাইন করতে হয়। টেবিলের ফিল্ডকে প্রাইমারি কী দ্বারা নির্ধারণ করা হলে ঐ ফিল্ডে কোন ডুপ্লিকেট ডেটা টাইপ করা যাবে না এবং ঐ ফিল্ডটিকে খালি (Null) রাখা যাবে না।

1 thought on “এক্সেস টেবিল রিলেশন করা । এক্সেস ২০১৬ বাংলা টিউটোরিয়াল – পর্ব ৮”

  1. ডেটাবেজ তৈরি করা । এক্সেস ২০১৬ বাংলা টিউটোরিয়াল – পর্ব 7 খুঁজে পাওয়া যায় নি
    দয়াকরে লিংকটি দিন

Comments are closed.

error: Content is protected !!
Scroll to Top