我的 Rails 3 应用程序中有三个模型,并且DailyData
是多对多关系。DailyDataVehicle
Vehicle
我刚刚了解到,如果您使用关联更新模型,它不会更新数据库,因此我将返回并添加这些迁移。我也很幸运地自信地认为我知道 和 之间的区别belongs_to
,has_many
但是,在我的迁移文件中,我不确定是否知道t.references
。
所以我将迁移模型命名为AddDailyDataToDailyDataVehicle
,并希望将其添加dailyData_id
到daily_data_vehicles
表中。这是一个多对多关系,所以我希望id key
在关系表中DailyDataVehicles
,但我不太确定t.references
会知道这一点。
也许我稍微混淆了类关联和数据库关系,如果是,请澄清这一点。
如果t.references
不是我想要的,我是否必须手动声明关系has_many
,如果是,那么语法是什么?
架构文件当前:
create_table "daily_data_vehicles", :force => true do |t|
t.integer "vehicle_id"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end
add_index "daily_data_vehicles", ["vehicle_id"], :name => "index_daily_data_vehicles_on_vehicle_id"
迁移(尝试):
class AddDailyDataToDailyDataVehicle < ActiveRecord::Migration
def change
change_table :dailyDataVehicles do |t|
t.references :dailyData
end
add_index :dailyDataVehicles, :dailyData_id
end
end
如果迁移工作正常,我认为架构文件应该是什么样子:
create_table "daily_data_vehicles", :force => true do |t|
t.integer "vehicle_id"
t.integer "dailyData_id"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end
add_index "daily_data_vehicles", ["vehicle_id"], :name => "index_daily_data_vehicles_on_vehicle_id"
add_index "daily_data_vehicles", ["dailyData_id"], :name => "index_daily_data_vehicles_on_daily_data_id"
不同的是t.integer "dailyData_id"
和add_index "daily_data_vehicles", ["dailyData_id"], :name => "index_daily_data_vehicles_on_daily_data_id"