定义索引:
在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。
Rails默认建立的索引名称为:index_table_on_column。可以使用额外的:name =>
"somename"改变索引的默认名称。需要注意的是,如果在self.up方法中使用了:name参数建立索引,那在self.down中也需要使
用:name来移除相应的那个索引。
Rails也支持建立复合索引:单个索引建立在多个字段上。建立复合索引的方法很简单,只需要将关联的column组成一个数组传递给self.up即可。如果采用这种方式的话,索引的名称会参照column数组中第一个元素的名称。
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
分享到:
- 2008-11-24 17:19
- 浏览 2622
- 评论(0)
- 论坛回复 / 浏览 (0 / 1969)
- 查看更多
相关推荐
gem "mongoid_rails_migrations" 如何使用 创建迁移 $ rails generate mongoid:migration 运行迁移: $ rails db:migrate $ rails db:migrate:down VERSION= $ rails db:migrate:up VERSION= $ rails db:rollback...
mongoid_rails_migrations, Mongoid的数据迁移 发行说明最新版本,1.1. x, 目标 Mongoid> = 4.0.0和 Rails> = 4.2.0.对于 Rails> = 3.2.0和 Mongoid> = 3.0.0,使用版本 1.0.0.
在Ruby on Rails中文指南中,你将全面学习到如何利用这个强大的框架来构建动态的、数据驱动的Web应用程序。 首先,让我们深入理解Rails的核心概念: 1. **路由(Routes)**:Rails的路由系统是应用程序的导航蓝图...
适用于Nova的Rails迁移扩展提供命令以轻松访问Rails项目中的迁移。特征快速打开最新的Rails迁移从您的迁移列表中选择一个特定的迁移安装下载最新。 解压缩档案。 双击RailsMigrations.novaextension将扩展安装在Nova...
12. **Migrations**:Rails的迁移机制允许开发者通过Ruby代码来管理数据库结构的变化,使得数据库版本控制变得简单。 学习Rails指南中文版,开发者将全面了解Rails的各个方面,包括基础概念、核心组件、最佳实践...
2. **数据库迁移(Database Migrations)**:Rails使用ActiveRecord和SQLite、MySQL或PostgreSQL等数据库系统交互。开发者通过编写迁移文件来定义和修改数据库结构。 3. **路由(Routing)**:Rails的路由系统根据...
此外,Rails的迁移(Migrations)系统允许你对数据库结构进行修改,如创建新表: ```bash rake db:create # 创建数据库 rake db:migrate # 应用迁移文件,生成对应的数据库表 ``` Rails的scaffold命令是一个强大的...
- **数据库迁移(Database Migrations)**:Rails使用迁移来管理数据库结构的变化。通过`rails generate migration AddTitleToPosts title:string`创建迁移,然后运行`rails db:migrate`执行迁移。 - **...
- 探讨了组件化应用中的迁移(Migrations)管理,也就是如何在组件内处理数据表的迁移。 5. 组件类型: - 书中可能会提到不同类型的Rails引擎,比如Plain Engine、Full Engine和Mountable Engine,并解释它们之间...
在Rails中,Ruby的元编程能力使得框架能够灵活地自定义和扩展。 Rails的核心理念是DRY(Don't Repeat Yourself),鼓励代码重用,避免重复编写相似的代码。此外,它还提供了大量的内置功能和库,如ActiveRecord用于...
在Rails项目中,我们首先需要了解的是项目的目录结构。一个标准的Rails应用会包含以下关键部分: 1. **app**:应用程序的核心,包括模型(models)、视图(views)和控制器(controllers)。模型负责业务逻辑和数据...
4. **Rails 数据库迁移(Migrations)**: Migrations 是 Rails 中用于数据库结构版本控制的工具。它们允许开发者以编程方式添加、修改或删除表列,而不必直接操作 SQL。文件将涵盖创建、运行和回滚迁移,以及使用 `...
在Rails中,可以配置数据库连接信息,使用`database.yml`文件。安装MySQL后,通过Gemfile中的`gem 'mysql2'`来添加MySQL驱动,接着运行`bundle install`安装依赖。 4. **Rails基础知识** - **模型(Model)**:...
6. **数据库迁移(Database Migrations)**:Rails提供了方便的工具来创建和更新数据库结构。购物车功能可能涉及到创建新的表,如`cart_items`和`orders`。 7. **测试(Testing)**:为了确保代码的健壮性和正确性...
该文档详细介绍了Rails 2.1版本中引入的新特性和改进之处,对于Rails开发者来说,是一份非常有价值的参考资料。 #### 新特性介绍 **时间区(Timezones)** Rails 2.1增加了对时区的支持,这意味着应用程序可以更...
本压缩包中的"Ruby on Rails入门经典代码"提供了新手学习Rails的宝贵资源,帮助初学者快速掌握这个强大的框架。 1. **Rails基础知识**: - MVC架构:Rails的核心设计模式,模型负责数据处理,视图负责展示,控制器...
在Rails中,`模型`负责处理数据和业务逻辑,`视图`负责展示用户界面,而`控制器`则作为模型和视图之间的桥梁,处理用户请求并协调它们之间的交互。Rails的许多特性,如ActiveRecord(ORM)、ActiveModel、Action...
7. **Migrations and Database Schema**: 书中详细讲解了如何使用Rails的迁移(migrations)来管理数据库结构的变化,以及如何编写有效的数据库模式(schema)。 8. **Testing**: 对于Rails应用,测试是必不可少的一...
3. **数据库迁移(Migrations)**:Rails提供了一种方便的方式来管理数据库结构的改变,即迁移。在`db/migrate`目录下创建迁移文件,通过运行`rake db:migrate`命令,你可以同步数据库结构与应用的模型。 4. **视图...