aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Dyba <daniel.dyba@gmail.com>2011-06-29 23:21:09 -0700
committerDaniel Dyba <daniel.dyba@gmail.com>2011-06-29 23:21:09 -0700
commitb367f961bbab12910f55212a614f85693aec424a (patch)
tree27b267ef4aca2b35d00d4163922a0e72227da42f
parent7d3a61a0e2bbcd6cf4fbeaa6aec5fc1d52a389d4 (diff)
parent1028226b00a3671a465b510880bd186ae26b2e3d (diff)
downloadrails-b367f961bbab12910f55212a614f85693aec424a.tar.gz
rails-b367f961bbab12910f55212a614f85693aec424a.tar.bz2
rails-b367f961bbab12910f55212a614f85693aec424a.zip
Merge pull request #49 from dyba/master
Separated the ActiveRecord Supported Types in a separate section
-rw-r--r--Gemfile1
-rw-r--r--railties/guides/source/migrations.textile39
2 files changed, 28 insertions, 12 deletions
diff --git a/Gemfile b/Gemfile
index ef9f613955..0c65d74669 100644
--- a/Gemfile
+++ b/Gemfile
@@ -11,6 +11,7 @@ end
gem "coffee-script"
gem "sass"
gem "uglifier", ">= 1.0.0"
+gem "w3c_validators"
gem "rake", ">= 0.8.7"
gem "mocha", ">= 0.9.8"
diff --git a/railties/guides/source/migrations.textile b/railties/guides/source/migrations.textile
index dbbf8f3b51..eae337b67b 100644
--- a/railties/guides/source/migrations.textile
+++ b/railties/guides/source/migrations.textile
@@ -117,6 +117,33 @@ Occasionally you will make a mistake when writing a migration. If you have alrea
In general editing existing migrations is not a good idea: you will be creating extra work for yourself and your co-workers and cause major headaches if the existing version of the migration has already been run on production machines. Instead you should write a new migration that performs the changes you require. Editing a freshly generated migration that has not yet been committed to source control (or more generally which has not been propagated beyond your development machine) is relatively harmless.
+h4. Supported Types
+
+Active Record supports the following types:
+
+* +:primary_key+
+* +:string+
+* +:text+
+* +:integer+
+* +:float+
+* +:decimal+
+* +:datetime+
+* +:timestamp+
+* +:time+
+* +:date+
+* +:binary+
+* +:boolean+
+
+These will be mapped onto an appropriate underlying database type, for example with MySQL +:string+ is mapped to +VARCHAR(255)+. You can create columns of types not supported by Active Record when using the non-sexy syntax, for example
+
+<ruby>
+create_table :products do |t|
+ t.column :name, 'polygon', :null => false
+end
+</ruby>
+
+This may however hinder portability to other databases.
+
h3. Creating a Migration
h4. Creating a Model
@@ -261,18 +288,6 @@ end
will append +ENGINE=BLACKHOLE+ to the SQL statement used to create the table (when using MySQL the default is +ENGINE=InnoDB+).
-The types supported by Active Record are +:primary_key+, +:string+, +:text+, +:integer+, +:float+, +:decimal+, +:datetime+, +:timestamp+, +:time+, +:date+, +:binary+, +:boolean+.
-
-These will be mapped onto an appropriate underlying database type, for example with MySQL +:string+ is mapped to +VARCHAR(255)+. You can create columns of types not supported by Active Record when using the non-sexy syntax, for example
-
-<ruby>
-create_table :products do |t|
- t.column :name, 'polygon', :null => false
-end
-</ruby>
-
-This may however hinder portability to other databases.
-
h4. Changing Tables
A close cousin of +create_table+ is +change_table+, used for changing existing tables. It is used in a similar fashion to +create_table+ but the object yielded to the block knows more tricks. For example