我正在尝试按如下方式构建联接:
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构建的默认列以外的其他列加入。
有不同的方法吗?
编辑:我更新了包含我的实际表名。
答案 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”
编辑:使用表名更新