Database Migration এবং Versioning গাইড ও নোট

Web Development - ওয়েব২পাই (Web2Py) - Advanced Database Features
178

Web2Py তে Database Migration এবং Versioning গুরুত্বপূর্ণ প্রক্রিয়া, যা আপনাকে ডাটাবেসের কাঠামো এবং স্কিমা পরিবর্তন বা আপডেট করার সুযোগ দেয়, যখন আপনার অ্যাপ্লিকেশন বৃদ্ধি পায় এবং নতুন ফিচার যুক্ত হয়। ডাটাবেস মাইগ্রেশন একটি প্রক্রিয়া যা ডাটাবেসের পূর্ববর্তী সংস্করণ থেকে বর্তমান সংস্করণে পরিবর্তন এনে সঠিকভাবে কাজ করতে সহায়তা করে।

এখানে Web2Py তে Database Migration এবং Versioning সম্পর্কিত প্রক্রিয়া বিস্তারিতভাবে ব্যাখ্যা করা হলো।


Web2Py তে Database Migration

Database Migration হল ডাটাবেসের কাঠামো (schema) পরিবর্তন বা আপডেট করার প্রক্রিয়া। যেমন নতুন টেবিল তৈরি করা, কলাম যোগ করা বা মুছে ফেলা, ডেটা টাইপ পরিবর্তন করা, বা অন্যান্য কাঠামোগত পরিবর্তন করা।

১. Web2Py তে ডাটাবেস মাইগ্রেশন

Web2Py তে ডাটাবেস মাইগ্রেশন করার জন্য এটি db.define_table ব্যবহার করে এবং db মডিউলের মাধ্যমে টেবিল তৈরি ও মডিফাই করা হয়। আপনি মাইগ্রেশন করার সময় Python scripts ব্যবহার করে বিভিন্ন পরিবর্তন করতে পারেন।

উদাহরণ: ডাটাবেস মাইগ্রেশন

ধরা যাক, আপনি একটি নতুন book টেবিল তৈরি করেছেন এবং এটি আপডেট করতে চান।

# models/db.py
db.define_table('book',
                Field('title', 'string'),
                Field('author', 'string'),
                Field('publish_date', 'date'))

# প্রথম মাইগ্রেশন, নতুন টেবিল তৈরি

এখন, যদি আপনি book টেবিলে একটি নতুন price কলাম যোগ করতে চান, তাহলে আপনি নতুন মাইগ্রেশন স্ক্রিপ্ট লিখবেন।

# models/db.py (মাইগ্রেশন ২)
db.book.add_column('price', 'double')  # নতুন price কলাম যোগ করা

২. Web2Py তে মাইগ্রেশন স্ক্রিপ্ট ব্যবহার করা

Web2Py তে Database Migration করার জন্য আপনি migrate=True ফ্ল্যাগ ব্যবহার করতে পারেন, যা স্বয়ংক্রিয়ভাবে ডাটাবেস স্কিমা আপডেট করতে সহায়তা করে। তবে, যদি আপনার মাইগ্রেশন স্ক্রিপ্টের মাধ্যমে অনেক পরিবর্তন করা হয়, আপনি নিজেই মাইগ্রেশন স্ক্রিপ্ট তৈরি করতে পারেন।

উদাহরণ: মাইগ্রেশন ফ্ল্যাগ ব্যবহার
# models/db.py
db.define_table('book',
                Field('title', 'string'),
                Field('author', 'string'),
                Field('publish_date', 'date'),
                Field('price', 'double'),
                migrate=True)  # মাইগ্রেশন ফ্ল্যাগ

এখন, Web2Py এই স্কিমা পরিবর্তনগুলো অ্যাপ্লিকেশনের ডাটাবেসে স্বয়ংক্রিয়ভাবে অ্যাপ্লাই করবে।

৩. ডাটাবেস মাইগ্রেশন ফাইল

Web2Py তে মাইগ্রেশন ফাইলগুলি সাধারণত migrate ফোল্ডারে থাকে। এগুলো ডাটাবেসের কাঠামোগত পরিবর্তনগুলো ট্র্যাক এবং লেটার ব্যবহার করতে সহায়তা করে।

আপনি manual বা automatic migration scripts ব্যবহার করতে পারেন। উদাহরণস্বরূপ, আপনি migrate ফোল্ডারে SQL স্ক্রিপ্ট তৈরি করতে পারেন যা ডাটাবেস পরিবর্তন করবে।


Web2Py তে Database Versioning

Database Versioning হল ডাটাবেসের সংস্করণ নিয়ন্ত্রণের প্রক্রিয়া, যেখানে বিভিন্ন ডাটাবেস পরিবর্তন বা আপডেটের জন্য সংস্করণ ট্র্যাক করা হয়। যখন আপনার অ্যাপ্লিকেশন বড় হয় এবং আপনি একাধিক ডেভেলপার বা পরিবেশে কাজ করেন, তখন ডাটাবেস সংস্করণ নিয়ন্ত্রণ জরুরি হয়ে পড়ে।

১. Database Versioning Tools

Web2Py ডাটাবেস ভার্সনিংয়ের জন্য সরাসরি কোনো টুল সরবরাহ না করলেও, আপনি Git বা অন্যান্য ভার্সন কন্ট্রোল টুলস ব্যবহার করে মাইগ্রেশন স্ক্রিপ্টের সংস্করণ ট্র্যাক করতে পারেন।

উদাহরণ: মাইগ্রেশন স্ক্রিপ্ট ট্র্যাক করা
  1. আপনার মাইগ্রেশন স্ক্রিপ্টগুলি migrations/ ফোল্ডারে রাখতে পারেন এবং এই স্ক্রিপ্টগুলি Git এর মাধ্যমে ট্র্যাক করতে পারেন।
  2. প্রতিটি মাইগ্রেশন স্ক্রিপ্টের নামকরণ করুন, যেমন 001_initial_schema.py, 002_add_price_column.py ইত্যাদি।
  3. আপনার ডাটাবেস স্কিমা পরিবর্তন হলে, আপনি Git commit এর মাধ্যমে স্ক্রিপ্টগুলি ভার্সন কন্ট্রোল করতে পারেন।

২. Manual Versioning with Migration Scripts

Web2Py তে আপনি ম্যানুয়ালি ডাটাবেসের সংস্করণ পরিচালনা করতে পারেন। এই কাজটি সাধারণত মাইগ্রেশন স্ক্রিপ্ট এবং ডাটাবেস চেক ব্যবহার করে করা হয়।

উদাহরণ: মাইগ্রেশন স্ক্রিপ্টের সংস্করণ তৈরি করা
# migrations/001_initial_schema.py
db.define_table('book',
                Field('title', 'string'),
                Field('author', 'string'),
                Field('publish_date', 'date'))

# migrations/002_add_price_column.py
db.book.add_column('price', 'double')

এখানে, প্রথম মাইগ্রেশন 001_initial_schema.py তৈরি করে নতুন টেবিল, এবং পরবর্তী মাইগ্রেশন 002_add_price_column.py কলাম যুক্ত করে।

৩. Rollback Feature

Web2Py তে rollback মেকানিজম বা আগের সংস্করণে ফিরে যাওয়ার জন্য বিশেষভাবে কোনও সরাসরি ফিচার নেই, তবে আপনি আপনার ডাটাবেসের backup তৈরি করে রাখতে পারেন এবং প্রয়োজনে manual rollback করতে পারেন।

উদাহরণ: ম্যানুয়াল রোলব্যাক
# models/db.py
db.book.drop()  # ড্রপ করার মাধ্যমে টেবিল মুছে ফেলা

এটি মাইগ্রেশন প্রক্রিয়ার অংশ হিসেবে পূর্ববর্তী সংস্করণে ফিরে যাওয়ার জন্য ব্যবহার করা যেতে পারে, তবে এর আগে ব্যাকআপ নেওয়া গুরুত্বপূর্ণ।


Web2Py তে Database Migration Best Practices

  1. টেবিল এবং ফিল্ড নামকরণের একটি সুসংগত নিয়ম তৈরি করুন: মাইগ্রেশন স্ক্রিপ্টগুলোর মধ্যে নামের কনভেনশন বজায় রাখুন (যেমন: 001_initial_schema.py, 002_add_column.py)।
  2. ডাটাবেস ব্যাকআপ নিয়মিত নিন: মাইগ্রেশন প্রক্রিয়ার আগে ব্যাকআপ নিতে ভুলবেন না। আপনি pg_dump (PostgreSQL) বা mysqldump (MySQL) ব্যবহার করে ডাটাবেস ব্যাকআপ নিতে পারেন।
  3. Git বা অন্য কোনো ভার্সন কন্ট্রোল সিস্টেম ব্যবহার করুন: আপনার মাইগ্রেশন স্ক্রিপ্ট এবং ডাটাবেস পরিবর্তনগুলি ট্র্যাক করতে Git বা অন্য কোনও ভার্সন কন্ট্রোল সিস্টেম ব্যবহার করুন।
  4. পরীক্ষা (Testing): ডাটাবেস মাইগ্রেশন করার আগে উন্নয়ন (development) পরিবেশে মাইগ্রেশনটি পরীক্ষা করুন, যেন কোনো ত্রুটি না ঘটে।
  5. মাইগ্রেশন স্ক্রিপ্টের কাস্টমাইজেশন: Web2Py তে ডিফল্টভাবে মাইগ্রেশন সিস্টেম রয়েছে, তবে আপনি প্রয়োজনে কাস্টম মাইগ্রেশন স্ক্রিপ্ট তৈরি করতে পারেন।

সারাংশ

Web2Py তে Database Migration এবং Versioning গুরুত্বপূর্ণ প্রক্রিয়া, যা ডাটাবেসের কাঠামো এবং সংস্করণ সঠিকভাবে পরিচালনা করতে সাহায্য করে। SQLFORM এবং db.define_table এর মাধ্যমে আপনি ডাটাবেস টেবিল তৈরি ও মডিফাই করতে পারেন এবং migration scripts ব্যবহার করে ডাটাবেস আপডেট করতে পারেন। এছাড়া, Git এবং manual migration scripts ব্যবহার করে ডাটাবেসের সংস্করণ কন্ট্রোল করা যায়, যা একটি বড় প্রকল্পে খুবই কার্যকর।

Content added By
Promotion

Are you sure to start over?

Loading...