开发者

establish_connection doesn't seem to support joins

开发者 https://www.devze.com 2023-01-29 18:24 出处:网络
I\'m trying to move my User account and session data into a separate database so that we can eventually share it across multiple applications.

I'm trying to move my User account and session data into a separate database so that we can eventually share it across multiple applications.

I've seen plenty of people online saying to use establish_connection to tell a model to connect to a different db, but I am unable to get this to work.

config/database.yml

development:
  adapter: mysql2
  encoding: utf8
  reconnect: true
  pool: 5
  host: localhost
  database: project_name_development

authentication:
  adapter: mysql2
  encoding: utf8
  reconnect: true
  pool: 5
  host: localhost
  database: authentication

app/models/user.rb

class User < ActiveRecord::Base
  establish_connection :authenti开发者_运维问答cation
  has_one :person
end

app/models/person.rb

class Person < ActiveRecord::Base
  belongs_to :user
end

This much seems to be working:

> User.connection.instance_eval { @config[:database] }
=> "authentication"
> Person.connection.instance_eval { @config[:database] }
=> "project_name_development"

and I can query User in isolation:

> User.where(:admin => true)
=> [ ... lots of results .. ]

but as soon as I try to use join it breaks:

> User.joins(:person)
ActiveRecord::StatementInvalid: Mysql2::Error: Table 'authentication.people' doesn't exist: SELECT `users`.* FROM `users` INNER JOIN `people` ON `people`.`user_id` = `users`.`id`

ARel seems to be using the current database instead of getting the correct one through reflection.

I found this very old bug report from almost two years ago about this problem, but I am almost certain it was regarding the old ARel syntax, and I really doubt the code examples would work anymore.

Is this even possible?

Update: made a little headway by doing this:

User.joins("INNER JOIN project_name.people ON project_name.people.user_id = authentication.users.id")

but that is really tedious, and one of the tables I'd like to join is polymorphic.

I tried adding:

set_table_name 'project_name.people'

but that returns

NoMethodError: undefined method `eq' for nil:NilClass

It seems to me that Rails3 doesn't actually support multiple schemas. Am I wrong?


Have you thought about taking it out of the app layer and just replicating certain tables only with MySQL replication?

0

精彩评论

暂无评论...
验证码 换一张
取 消