0

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

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内置的默认值以外的不同列加入。

有不同的方法可以做到这一点吗?

编辑:我更新以包括我的实际表名。

4

2 回答 2

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”

编辑:用表名更新

于 2012-09-10T16:47:25.810 回答
0

任何正在寻找答案的人,只需使用它来获取您的数据 ->

@returned_fields = ActiveRecord::Base.connection.execute(sql)

这不会返回“模型”对象,而只是一个通用的 MySQL::Result 对象。使用它来获取数据->

@returned_fields.each

这会给你一个像这样的数组数组->

[[1,2], [3,4], etc...]

另外,请确保您使用数据库名称来限定您的表,如下所示 ->

SELECT foo FROM database.BAR as bar JOIN database.BLEZ as blez ON bar.COMPUTER_NAME = blez.Retrieving_Hostname

我的问题原来是数据库的限定。由于我没有资格,它在错误的数据库(我当前连接的那个)中寻找表。

于 2012-09-14T18:43:58.617 回答