Migrations流水帐

对于Rails的迁移功能Migrations,一直都只是看一下网上的一些很基础很基础的代码片断就开始动手写代码,对它的认识基本上就是停留在抄袭的层面,连会用都说不上.有感于此,终下决心要弄清楚Migrations,至少得会用啊,山寨抄袭终非王道.

学习Migrations最佳的学习资料莫过于 Ruby On Rails网站上的 Guides 系统文章了,链接在 [url]http://guides.rubyonrails.org/migrations.html[/url]
本文的很多代码都是出自那里.

在我的理解中,Migrations就是一个基于ruby,针对数据库(SQL)的DSL,它的出现也是符合Rails中处处皆Ruby的原则的,正是专注于Ruby,这样Rails才显得别样的美丽.

=========================== [b]如何写migration[/b] =========================

[list]
[b]1.migration的结构[/b]
[/list]
每一个migrate的类都是 ActiveRecord::Migration 的子类,每一个migrate都要重写两个方法 up 和 down:

class CreateProducts < ActiveRecord::Migration
def self.up
#想干嘛,就干嘛
end
def self.down
#你后悔的时候,你会怎么做?
end
end

简单的说 up 方法就是操作数据库时用的,down就是你后悔了,用来回滚用的.

[list]
[b]2.migration提供调用的方法[/b]
[/list]
Migrations提供了一系列的方法来操作数据库:

create_table #建表
change_table #修改表结构
drop_table #删除表
add_column #增加字段
change_column #修改字段定义
rename_column #修改字段名
remove_column #删除字段
add_index #创建索引
remove_index #删除索引

具体各个方法的详细定义,可以查看Rails的API [url]http://api.rubyonrails.org/classes/ActiveRecord/Migration.html[/url]
这些方法替代使用SQL来操作数据库,当然也可以使用 execute 方法直接使用 SQL 来操作数据库,个人不推荐这种方式,但是在某些情况下,提供直接使用SQL也是很方便的:

execute <<-SQL
ALTER TABLE products ADD CONSTRAINT fk_products_categories FOREIGN KEY (category_id) REFERENCES categories(id)
SQL


[list]
[b]3.字段[/b]
[/list]
定义字段有两种方法:

#这个是传统的方法
create_table :products do |t|
t.column :name, :string, :null => false
end

#这个刚出来的时候,大家都说很性感,其实不外乎就是定义一系列的快捷方法: string,
# text, integer, float, decimal, datetime, timestamp, time, date,
# binary, boolean . 这一系列的方法对应各种数据类型,
# 还有 primary_key 方法是用来定义主键的.
create_table :products do |t|
t.string :name
end

除了这几个经典的定义字段方法外,还有两个特别的Helper方法:

#以下这个方法会自动在表中增加 created_at,updated_at这两个类型为timestamp的字段
change_table :products do |t|
t.timestamps
end

#这个方法是定义关于关系的,但是不会为你的表加上外键约束,如果你加上约束,请另外手动添加,切记!
create_table :products do |t|
t.references :category # 生成 category_id

#这个是关联关系中多态的定义,生成两个字段 attachment_id 和 attachment_type ,并且attachment_type的默认值为 'Photo'
t.references :attachment, :polymorphic => {:default => 'Photo'}
end

以上两个方法是锦上添花之作,相当的实用.

[list]
[b]4.在migration中使用 Model[/b]
[/list]
除了使用以上方法操作数据库外,其实还可以直接在migration中使用 Model 的.比如:

def self.up
#直接就用model来更新数据库,
#你可以看到 migration 一直在提供便利让你避免使用SQL,当然不是说SQL不好,只是想让你更加的统一,只要ruby就好了.
User.update_all ["receive_newsletter = ?", true]
end


使用model的另外一种情况是:当前migration要删除表中的一个字段 first_name,但是你的model中的某个方法使用了这个字段作为验证,比如:

class User < ActiveRecord::Base
validates_presence_of :first_name
end

那么当你要在migration中增加一条记录时,这个验证便不能通过,如:

def self.up
User.create({:name => 'name'}).save
end

在这种情况下,你可以在migration中重新定义一个model:

class XXXMigration < ActiveRecord::Migration
class User < ActiveRecord::Base
end
def self.up
remove_column :first_name
end

#这个方法的作用就是取得最新的表定义
User.reset_column_information
#放心吧,这个User不会有 validates_presence_of :first_name 的验证
User.create({:name => 'name'}).save


=========================== [b]migration文件的命名[/b] =======================

按照Migration的约定去命名你的migration文件,会令你省不少功夫的,请千万要相信这一点.
如果migration文件名是这样的格式: AddXXXToYYY” or “RemoveXXXFromYYY
XXX => 字段名, YYY => 表名.
那么migration生成的时候,Rails会自动为你加上 add_column or remove_column
比如:

#留意类名
class AddPartNumberToProducts < ActiveRecord::Migration
def self.up
add_column :products, :part_number, :string
end
def self.down
remove_column :products, :part_number
end
end

class RemovePartNumberFromProducts < ActiveRecord::Migration
def self.up
remove_column :products, :part_number
end
def self.down
add_column :products, :part_number, :string
end
end

cool吧??

=========================== [b]如何执行migration[/b] =========================

执行migration的经典方法:

rake db:migrate

#执行特定版本
rake db:migrate VERSION=20080906120000

#屏蔽migration的输出
rake db:migrate VERBOSE=false

#你又后悔,可以用如下方法回滚到最近的一次migration执行的状态
rake db:rollback

#回滚到最近的3次,题外话,关于这个STEP=3到底是保存在那里的,我不曾找到,在数据库的schema_migrations表中,只有版本的信息
#莫非是按schema_migrations表记录的顺序?这个还要验证一下.
rake db:rollback STEP=3


=========================== [b]导出migration[/b] =========================

在某些时候,你可能需要导出migration对数据库表的字义,可以导出的格式有 rb 和 sql文件两种,前一种是正宗的ruby文件,后一种是对应你使用的数据库的SQL文件.

rb:大家都知道要查看某个model的属性时,只能去db/migrate中找定义文件,但是有了这个migration的定义文件后,只要打开它就能看了.
sql:很多时候,程序员是没有权限操作数据库的,或者没有ruby环境,这时候导出的sql定义文件就有用了.

至于你需要那一种,可以配置一下 config/environment.rb

config.active_record.schema_format => :sql # or :rb


然后执行:

rake db:structure:dump

到 RAILS_ROOT/db 目录下看看吧.

==================================================================

写完了,其实这里没有多少我的东西,大部分出自 [url]http://guides.rubyonrails.org/migrations.html[/url] ,我只不过把英文变成中文罢了.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
4S店客户管理小程序-毕业设计,基于微信小程序+SSM+MySql开发,源码+数据库+论文答辩+毕业论文+视频演示 社会的发展和科学技术的进步,互联网技术越来越受欢迎。手机也逐渐受到广大人民群众的喜爱,也逐渐进入了每个用户的使用。手机具有便利性,速度快,效率高,成本低等优点。 因此,构建符合自己要求的操作系统是非常有意义的。 本文从管理员、用户的功能要求出发,4S店客户管理系统中的功能模块主要是实现管理员服务端;首页、个人中心、用户管理、门店管理、车展管理、汽车品牌管理、新闻头条管理、预约试驾管理、我的收藏管理、系统管理,用户客户端:首页、车展、新闻头条、我的。门店客户端:首页、车展、新闻头条、我的经过认真细致的研究,精心准备和规划,最后测试成功,系统可以正常使用。分析功能调整与4S店客户管理系统实现的实际需求相结合,讨论了微信开发者技术与后台结合java语言和MySQL数据库开发4S店客户管理系统的使用。 关键字:4S店客户管理系统小程序 微信开发者 Java技术 MySQL数据库 软件的功能: 1、开发实现4S店客户管理系统的整个系统程序; 2、管理员服务端;首页、个人中心、用户管理、门店管理、车展管理、汽车品牌管理、新闻头条管理、预约试驾管理、我的收藏管理、系统管理等。 3、用户客户端:首页、车展、新闻头条、我的 4、门店客户端:首页、车展、新闻头条、我的等相应操作; 5、基础数据管理:实现系统基本信息的添加、修改及删除等操作,并且根据需求进行交流信息的查看及回复相应操作。
在计算机领域,live migration(实时迁移)是指在不中断正在运行的虚拟机的情况下将其从一台物理主机迁移到另一台物理主机的过程。这种迁移可以在虚拟机继续运行的同时进行,对用户来说是透明的。 live migration通常用于以下情况: 1. 负载均衡:通过将虚拟机从一个物理主机迁移到另一个物理主机,可以实现负载均衡,从而更好地利用资源。 2. 硬件维护:当需要对物理主机进行维护或升级时,可以将虚拟机迁移到其他物理主机上,以避免服务中断。 3. 故障恢复:当一台物理主机发生故障时,可以将其上的虚拟机迁移到其他正常运行的物理主机上,以实现快速恢复。 在live migration过程中,需要考虑一些参数来控制迁移的行为。其中,live_migration_downtime(实时迁移停机时间)表示迁移过程中虚拟机的停机时间,live_migration_downtime_steps(实时迁移停机时间步长)表示迁移过程中每个步骤的停机时间,live_migration_downtime_delay(实时迁移停机时间延迟)表示在迁移过程中每个步骤之间的延迟时间。 以下是一个live migration的示例代码: ```python live_migration_downtime = 5000 live_migration_downtime_steps = 7 live_migration_downtime_delay = 75 # 进行live migration def live_migration(): # 实现live migration的代码逻辑 pass # 设置live migration参数 def set_live_migration_parameters(downtime, steps, delay): live_migration_downtime = downtime live_migration_downtime_steps = steps live_migration_downtime_delay = delay # 调用live migration函数 live_migration() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值