Rails:创建自定义数据类型/创建速记

时间:2010-04-11 15:05:31

标签: ruby-on-rails ruby code-generation types customization

我想知道如何创建在rake迁移文件中使用的自定义数据类型。示例:如果要创建模型,则可以在迁移文件中添加列。它看起来像这样:

  def self.up
    create_table :products do |t|
      t.column :name, :string
      t.timestamps
    end
  end

我想知道如何创建这样的东西:

t.column :name, :my_custom_data_type

这样做的原因就是创建一个“货币”类型,它只不过是精度为8且比例为2的十进制数。由于我只使用MySQL,因此该数据库的解决方案足够了。

感谢您的反馈和意见!

1 个答案:

答案 0 :(得分:22)

您要做的是定义新的列创建方法,该方法提供创建自定义类型的选项。这主要是通过在迁移中添加类似t.integer ...的方法来完成的。诀窍是找出添加该代码的位置。

初始化程序目录中的某些位置放置了以下代码段:

module ActiveRecord::ConnectionAdapters
  class TableDefinition
    def currency (*args)
      options = args.extract_options!
      column_names = args
      options[:precision] ||= 8
      options[:scale] ||= 2
      column_names.each { |name| column(name, 'decimal', options) }
    end                                                                     
  end
end

现在您可以使用货币方法在您需要时定义货币列。

示例:

def self.up
  create_table :products do |t|
    t.currency :cost
    t.timestamps
  end
end

将货币列添加到现有表中:

def self.up
  change_table :products do |t|
    t.currency :sell_price
  end
end   

警告:我没时间测试它,所以没有保证。如果它不起作用,至少应该让你走上正确的轨道。