浏览 1968 次
锁定老帖子 主题:Rails中的Migrations(五)
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (1)
|
|
---|---|
作者 | 正文 |
发表时间:2008-11-24
定义索引: 在Rails中定义索引也非常的简单。例如在应用中发现,使用name字段对orders表进行检索时,速度较慢,便可是针对name字段增加一个索引,以增加检索速度。 请看下面的代码:
Class AddCustomerNameIndexToOrders < ActiveRecord::Migration def self.up add_index :orders, :name end def self.down remove_index :orders, :name end end 这段代码会对orders表的name字段添加一个索引,如果给add_index方法一个额外的参数,:unique => true, 则会给这个字段添加一个唯一索引,同时时这个字段的属性为unique。 Primary Keys: Rails会假设数据库中的每张表都会有一个数字类型的主键(名称一般都为id)。
Rails假设这个id字段针对表中的每一条记录都是unique的。事实上,Rails对主键生成的规则是非常挑剔的,如果主键是一个数字型的
话,Rails会工作的很好,否则的话将会有不少繁琐的问题。所以强烈建议开发中遵循Rails默认的主键生成规则。
如果你不满意Rails为你指定的默认的主键名称(id),则可以在创建表的时候指定主键的名称。例如以下的代码: create_table :tickets, :primary_key => :number do |t| t.text :description t.timestamps end 这段代码建立的表tickets的主键名称就为number。
没有主键的表: 实际应用的数据库中存在一些没有主键的表--典型的是一些关联表。即为了连接两张存在多对多关系表而存在的表,一般这种表只有两个字段,分别为需要关联的两张表的主键。为了建立这种类型的表,需要在migration中特别给出参数,使Rails不要自动为表生成主键,具体请看以下的代码:
create_table :authoer_books, :id => false do |t| t.integer :author_id, :null => false t.integer :book_id, :null => false end 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |