रूबी ऑन रेल्स - माइग्रेशन
रेल माइग्रेशन आपको रूबी का उपयोग अपने डेटाबेस स्कीमा में परिवर्तन को परिभाषित करने के लिए करने की अनुमति देता है, जिससे वास्तविक कोड के साथ चीजों को सिंक्रनाइज़ रखने के लिए एक संस्करण नियंत्रण प्रणाली का उपयोग करना संभव हो जाता है।
इसके कई उपयोग हैं, जिनमें शामिल हैं -
Teams of developers - यदि एक व्यक्ति एक स्कीमा परिवर्तन करता है, तो अन्य डेवलपर्स को बस अद्यतन करने की आवश्यकता है, और "रेक माइग्रेट" चलाएं।
Production servers - "रेक माइग्रेट" चलाएं जब आप डेटाबेस के साथ-साथ डेट तक लाने के लिए एक नया रिलीज़ रोल करते हैं।
Multiple machines - यदि आप एक डेस्कटॉप और एक लैपटॉप, या एक से अधिक स्थानों पर विकसित होते हैं, तो माइग्रेशन आपको उन सभी को सिंक्रनाइज़ रखने में मदद कर सकता है।
प्रवासन क्या कर सकता है?
- create_table (नाम, विकल्प)
- drop_table(name)
- rename_table (old_name, new_name)
- add_column (table_name, column_name, प्रकार, विकल्प)
- rename_column (table_name, column_name, new_column_name)
- change_column (table_name, column_name, प्रकार, विकल्प)
- remove_column (table_name, column_name)
- add_index (table_name, column_name, index_type)
- remove_index (table_name, column_name)
Migrations support all the basic data types - निम्नलिखित डेटा प्रकारों की सूची है जो माइग्रेशन का समर्थन करता है -
string - एक टाइटल जैसे छोटे डेटा प्रकारों के लिए।
text - पाठ डेटा के लंबे टुकड़ों के लिए, जैसे विवरण।
integer - पूरे नंबरों के लिए।
float - दशमलव के लिए।
datetime and timestamp - दिनांक और समय को एक कॉलम में संग्रहीत करें।
date and time - या तो केवल तारीख या समय ही स्टोर करें।
binary - इमेज, ऑडियो या मूवी जैसे डेटा को स्टोर करने के लिए।
Boolean - सही या गलत मूल्यों के भंडारण के लिए।
Valid column options are - निम्नलिखित वैध कॉलम विकल्पों की सूची है।
limit (: सीमा => "50")
default ((डिफ़ॉल्ट => "ब्ला")
null((null => false का तात्पर्य है NULL नहीं )
NOTE - रेल माइग्रेशन द्वारा की गई गतिविधियाँ किसी भी फ्रंट-एंड GUI या सीधे SQL प्रॉम्प्ट का उपयोग करके की जा सकती हैं, लेकिन रेल माइग्रेशन उन सभी गतिविधियों को बहुत आसान बना देता है।
इन पर विवरण के लिए रेल एपीआई देखें ।
माइग्रेशन बनाएँ
माइग्रेशन बनाने के लिए यहाँ जेनेरिक सिंटैक्स दिया गया है -
application_dir> rails generate migration table_name
यह फ़ाइल db / migrate / 001_table_name.rb बनाएगा। एक माइग्रेशन फ़ाइल में मूल रूबी सिंटैक्स होता है जो डेटाबेस तालिका की डेटा संरचना का वर्णन करता है।
NOTE - माइग्रेशन जनरेटर चलाने से पहले, मॉडल जनरेटर द्वारा उत्पन्न मौजूदा माइग्रेशन को साफ करने की सिफारिश की जाती है।
हम अपनी तीन तालिकाओं के अनुरूप दो माइग्रेशन बनाएंगे - books and subjects।
पुस्तकों का प्रवास इस प्रकार होना चाहिए -
tp> cd library
library> rails generate migration books
उपरोक्त कमांड निम्न कोड उत्पन्न करता है।
विषय प्रवास इस प्रकार होना चाहिए -
tp> cd library
library> rails generate migration subjects
उपरोक्त कमांड निम्न कोड उत्पन्न करता है।
ध्यान दें कि आप माइग्रेशन बनाते समय पुस्तक और विषय और बहुवचन के लिए निचले मामले का उपयोग कर रहे हैं। यह एक रेल प्रतिमान है जिसे आपको माइग्रेशन बनाते समय हर बार पालन करना चाहिए।
कोड संपादित करें
अपने आवेदन के db / माइग्रेट करें और किसी भी सरल पाठ संपादक का उपयोग करके एक-एक करके प्रत्येक फ़ाइल को संपादित करें।
निम्नानुसार 001_books.rb संशोधित करें -
आईडी कॉलम अपने आप बन जाएगा, इसलिए इसे यहां भी न करें।
class Books < ActiveRecord::Migration
def self.up
create_table :books do |t|
t.column :title, :string, :limit => 32, :null => false
t.column :price, :float
t.column :subject_id, :integer
t.column :description, :text
t.column :created_at, :timestamp
end
end
def self.down
drop_table :books
end
end
प्रक्रिया self.up नए संस्करण में माइग्रेट करते समय उपयोग किया जाता है, self.downयदि आवश्यक हो तो किसी भी परिवर्तन को वापस करने के लिए उपयोग किया जाता है। इस समय, उपरोक्त स्क्रिप्ट का उपयोग बनाने के लिए किया जाएगाbooks तालिका।
निम्नानुसार 002_subjects.rb संशोधित करें -
class Subjects < ActiveRecord::Migration
def self.up
create_table :subjects do |t|
t.column :name, :string
end
Subject.create :name => "Physics"
Subject.create :name => "Mathematics"
Subject.create :name => "Chemistry"
Subject.create :name => "Psychology"
Subject.create :name => "Geography"
end
def self.down
drop_table :subjects
end
end
उपरोक्त स्क्रिप्ट बनाने के लिए उपयोग किया जाएगा subjects तालिका और विषय तालिका में पांच रिकॉर्ड बनाएगी।
माइग्रेशन चलाएं
अब जब आपने सभी आवश्यक माइग्रेशन फ़ाइलें बना ली हैं। यह डेटाबेस के खिलाफ उन्हें निष्पादित करने का समय है। ऐसा करने के लिए, कमांड प्रॉम्प्ट पर जाएं और लाइब्रेरी डायरेक्टरी में जाएं जिसमें एप्लिकेशन स्थित है, और फिर टाइप करेंrake migrate निम्नानुसार है -
library> rake db:migrate
यदि यह मौजूद नहीं है, तो यह एक "स्कीमा_इनफो" तालिका बनाएगा, जो डेटाबेस के वर्तमान संस्करण को ट्रैक करता है - प्रत्येक नया माइग्रेशन एक नया संस्करण होगा, और किसी भी नए माइग्रेशन को तब तक चलाया जाएगा जब तक कि आपका डेटाबेस वर्तमान संस्करण पर न हो।
Rakeरूबी बिल्ड प्रोग्राम है, जो यूनिक्स मेक प्रोग्राम के समान है, जो रेल का फायदा उठाता है, जटिल कार्यों के निष्पादन को आसान बनाता है जैसे डेटाबेस का ढांचा अपडेट करना आदि।
उत्पादन और परीक्षण डेटाबेस के लिए माइग्रेशन चलाना
यदि आप यह निर्दिष्ट करना चाहते हैं कि माइग्रेशन के लिए कौन से रेल वातावरण का उपयोग करना है, तो RIDS_ENV शेल चर का उपयोग करें।
उदाहरण के लिए -
library> export RAILS_ENV = production
library> rake db:migrate
library> export RAILS_ENV = test
library> rake db:migrate
library> export RAILS_ENV = development
library> rake db:migrate
NOTE- विंडोज में, एक्सपोर्ट कमांड के बजाय "सेट R नाखून_ENV = उत्पादन" का उपयोग करें ।
आगे क्या है?
अब हमारे पास हमारा डेटाबेस और आवश्यक टेबल उपलब्ध हैं। बाद के दो अध्यायों में, हम नियंत्रक (एक्शनकंट्रोलर) और व्यू (एक्शन व्यू) नामक दो महत्वपूर्ण घटकों का पता लगाएंगे।
- नियंत्रक (एक्शन कंट्रोलर) बनाना।
- दृश्य बनाना (एक्शन दृश्य)।