Rails:连接多个表,表'table1.table2'不存在

时间:2012-09-10 15:57:19

标签: ruby-on-rails-3 ruby-on-rails-3.2

我正在尝试按如下方式构建联接:

UserLog.find(:all, :joins => " JOIN client_inspector ON user_log.COMPUTER_NAME = client_inspector.Retrieving_Hostname ", :select=>  "DISTINCT user_log.COMPUTER_NAME, client_inspector.Retrieving_Hostname ")

但它给我以下错误 - >

ActiveRecord::StatementInvalid (Mysql2::Error: Table 'user_log.client_inspector' doesn't exist: SELECT DISTINCT user_log.COMPUTER_NAME, client_inspector.Retrieving_Hostname  FROM `user_log` JOIN client_inspector ON user_

log.COMPUTER_NAME = client_inspector.Retrieving_Hostname):

我理解MYSQL错误,但为什么Rails会这样做呢?

我没有创建任何将这两个表关联在一起的模型。我想做的是能够通过Ruby构建的默认列以外的其他列加入。

有不同的方法吗?

编辑:我更新了包含我的实际表名。

1 个答案:

答案 0 :(得分:0)

mysql请求有效。 我认为您的模型之间不需要关联。

使用复数名称创建模型的表名称,可以尝试:

UserLog.find(:all, :joins => " JOIN client_inspectors ON user_logs.COMPUTER_NAME = client_inspectors.Retrieving_Hostname ", :select=>  "DISTINCT user_logs.COMPUTER_NAME, client_inspectors.Retrieving_Hostname ")

在mysql查询中为每个表名添加“s”

编辑:使用表名更新