diff options
author | Giles Alexander <giles.alexander@gmail.com> | 2009-05-30 17:44:50 +1000 |
---|---|---|
committer | Michael Koziarski <michael@koziarski.com> | 2009-06-01 13:40:05 +1200 |
commit | 532219fd091837a9312a301c74e0fbf06abab3a8 (patch) | |
tree | 26867f3e59646342461055519131d234f37b117a /activerecord/lib | |
parent | b3839f1c98ab6824091c517f6e2e6e3a024c3e13 (diff) | |
download | rails-532219fd091837a9312a301c74e0fbf06abab3a8.tar.gz rails-532219fd091837a9312a301c74e0fbf06abab3a8.tar.bz2 rails-532219fd091837a9312a301c74e0fbf06abab3a8.zip |
Schema dumper now records scale 0 decimal columns as decimal not integer.
The schema dumper would dump out any decimal or numeric column that had a zero
scale as an integer column. This will cause problems for very large precision
columns on some DBMSs, particularly PostgreSQL. It also looks strange to see
your column change type after moving through schema.rb.
Signed-off-by: Michael Koziarski <michael@koziarski.com>
[#2741 state:committed]
Diffstat (limited to 'activerecord/lib')
-rw-r--r-- | activerecord/lib/active_record/schema_dumper.rb | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/schema_dumper.rb b/activerecord/lib/active_record/schema_dumper.rb index de530a3456..2d90ef35aa 100644 --- a/activerecord/lib/active_record/schema_dumper.rb +++ b/activerecord/lib/active_record/schema_dumper.rb @@ -99,8 +99,15 @@ HEADER next if column.name == pk spec = {} spec[:name] = column.name.inspect - spec[:type] = column.type.to_s - spec[:limit] = column.limit.inspect if column.limit != @types[column.type][:limit] && column.type != :decimal + + # AR has an optimisation which handles zero-scale decimals as integers. This + # code ensures that the dumper still dumps the column as a decimal. + spec[:type] = if column.type == :integer && [/^numeric/, /^decimal/].any? { |e| e.match(column.sql_type) } + 'decimal' + else + column.type.to_s + end + spec[:limit] = column.limit.inspect if column.limit != @types[column.type][:limit] && spec[:type] != 'decimal' spec[:precision] = column.precision.inspect if !column.precision.nil? spec[:scale] = column.scale.inspect if !column.scale.nil? spec[:null] = 'false' if !column.null |