通过has_many与多个数据库连接 [英] multiple database connections with has_many through

查看:92
本文介绍了通过has_many与多个数据库连接的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

如何通过使用多个数据库连接来创建has_many?

How can I make a has_many through work with multiple database connections?

我有一个名为 master的数据库,其中保存了位置信息。这是从单独的应用程序更新的。用户可以访问许多位置,但是所有其他模型都位于另一个名为预算的数据库中。

I have a database named "master" that holds the location information. That is updated from a separate application. Users can have access to many locations, but all the other models are located in another database named "budget". Here are how the models are setup.

# place.rb
class Place < ActiveRecord::Base
  belongs_to :user
  belongs_to :location
end

# user.rb
class User < ActiveRecord::Base
  has_many :locations, :through => :places
  has_many :places
end

# location.rb
class Location < ActiveRecord::Base
  establish_connection "master"
  has_many :places
  has_many :users, :through => :places
end

通过irb运行命令时,得到以下信息

When I run commands through irb, I get the following

> Location.first.places.create(:user_id => 1)
> #<Place id: 1, user_id: 1, location_id: 1, created_at: "2011-11-28 20:58:43",  updated_at: "2011-11-28 20:58:43">

> Location.first.places
> [#<Place id: 1, user_id: 1, location_id: 1, created_at: "2011-11-28 20:58:43", updated_at: "2011-11-28 20:58:43">]

> Location.first.users
> [#<User id: 1, username: "toby", role: "guest", created_at: "2011-11-28 17:45:40", updated_at: "2011-11-28 17:45:40">

> User.first.locations
> Mysql2::Error: Table 'master.places' doesn't exist: SELECT `locations`.* FROM `locations` INNER JOIN `places` ON `locations`.`id` = `places`.`location_id` WHERE `places`.`user_id` = 1 ActiveRecord::StatementInvalid: Mysql2::Error: Table 'master.places' doesn't exist: SELECT `locations`.* FROM `locations` INNER JOIN `places` ON `locations`.`id` = `places`.`location_id` WHERE `places`.`user_id` = 1

我尝试过将当前的rails env添加到Place,以尝试覆盖place的默认数据库,如下所示:
#place.rb
class Place< ActiveRecord :: Base
建立连接Rails.env
属性_到:用户
属性_到:位置
结束

I tried adding the current rails env to Place to try and override the default database for place, like this: # place.rb class Place < ActiveRecord::Base establish_connection Rails.env belongs_to :user belongs_to :location end

#database.yml

master:
  adapter: mysql2
  encoding: utf8
  reconnect: false
  database: master
  pool: 5
  username: root
  password:
  socket: /var/run/mysqld/mysqld.sock
development:
  adapter: mysql2
  encoding: utf8
  reconnect: false
  database: budget_development
  pool: 5
  username: root
  password:
  socket: /var/run/mysqld/mysqld.sock

那没有帮助。有想法吗?

That didn't help. Any ideas?

推荐答案

一个朋友为我回答了这个问题,我认为这可能对其他人有用。

A friend answered this for me, and I figured it might be of some use to others.

class Location < ActiveRecord::Base
  #establish_connection "master"
  def self.table_name() "master.locations" end
  has_many :places
  has_many :users, :through => :places
end

这篇关于通过has_many与多个数据库连接的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆