2

我的 Rails 3 应用程序中有三个模型,并且DailyData是多对多关系。DailyDataVehicleVehicle

我刚刚了解到,如果您使用关联更新模型,它不会更新数据库,因此我将返回并添加这些迁移。我也很幸运地自信地认为我知道 和 之间的区别belongs_tohas_many但是,在我的迁移文件中,我不确定是否知道t.references
所以我将迁移模型命名为AddDailyDataToDailyDataVehicle,并希望将其添加dailyData_iddaily_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"

4

1 回答 1

1
class AddDailyDataToDailyDataVehicle < ActiveRecord::Migration
  def change
    add_column :daily_data_vehicles, : daily_data_id, :integer
    add_index :daily_data_vehicles, :daily_data_id
  end
end

class DailyDataVehicle < ActiveRecord::Base
  belongs_to :daily_data
end

class DailyData < ActiveRecord::Base
  has_many :daily_data_vehicles
end
于 2012-12-13T05:59:23.210 回答