我想知道如何创建在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,因此该数据库的解决方案足够了。
感谢您的反馈和意见!
答案 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
警告:我没时间测试它,所以没有保证。如果它不起作用,至少应该让你走上正确的轨道。