我正在使用遗留数据库,该数据库为表product
和familia_producto
(rake db:schema:dump
)提供以下架构
create_table "producto", primary_key: "barcode", force: true do |t|
t.string "codigo_corto", limit: 16, null: false
t.string "marca", limit: 35
t.string "descripcion", limit: 50
t.string "contenido", limit: 10
t.string "unidad", limit: 10
t.float "stock", default: 0.0
t.float "precio"
t.float "precio_neto"
t.float "costo_promedio"
t.float "fifo"
t.float "vendidos"
t.boolean "aplica_iva"
t.integer "otros_impuestos", limit: 2
t.integer "familia", limit: 2, default: 1, null: false
t.integer "id_tipo_producto", limit: 2, null: false
t.boolean "es_perecible"
t.float "dias_stock", default: 1.0
t.float "margen_promedio", default: 0.0
t.boolean "es_venta_fraccionada"
t.float "stock_pro", default: 0.0
t.float "tasa_canje", default: 1.0
t.float "precio_mayor"
t.float "cantidad_mayor"
t.boolean "es_mayorista"
t.boolean "estado"
t.boolean "precio_editable"
end
create_table "familia_producto", force: true do |t|
t.string "nombre", limit: 32, null: false
end
在模型I'中
class FamiliaProducto < ActiveRecord::Base
self.table_name = 'familia_producto'
has_many :productos, :class_name => 'Producto', :primary_key => 'barcode', :foreign_key => 'familia'
end
class Producto < ActiveRecord::Base
self.table_name = 'producto'
belongs_to :familia_producto, :class_name => 'FamiliaProducto'
end
但是当我调用.familia
时,producto对象会抛出一个数字,而不是FamiliaProducto
对象。请帮忙!
2.1.0 :012 > p = Producto.all[0]
Producto Load (1.7ms) SELECT "producto".* FROM "producto"
=> #<Product......
2.1.0 :013 > p.familia
=> 2
2
应该是FamiliaProducto
对象。
答案 0 :(得分:54)
您必须使用关联的名称,还需要将外键添加到belongs_to
# Returns a FamiliaProducto object
p = Producto.first
p.familia_producto
# Producto model
belongs_to :familia_producto, class_name: 'FamiliaProducto', foreign_key: 'familia'
# FamiliaProducto model
has_many :productos, class_name: 'Producto', primary_key: 'id', foreign_key: 'familia'
# Returns an integer
p = Producto.first
p.familia