0

我是 Rails 新手,需要您的帮助来解决应该是一个简单的问题。

当我运行此代码时:

@search = User.search(params[:search])
@foundusers = @search.all.paginate :page => params[:page], :per_page => 20
@user = @search.where("users.id = ?", params[:id])
if @user.nil?
  @user = @foundusers.first
end
unless @user.company_id.nil?
  @company = Company.find(@user.company_id)
end

我收到以下错误声明:未定义的方法 `company_id' for #

我不明白,因为数据库上的查询是正确的 (SELECT users.* FROM usersLEFT OUTER JOIN companiesON companies. id= users. company_idWHERE ((( users. firstnameLIKE '%s%' OR users. lastnameLIKE '%s%') OR companies. nameLIKE '%s% ')) AND (users.id = '11'))

并且该用户的 company_id 不为空。

当我输入 puts @user.name 时,它​​没有给我用户名,而是给了我“用户”

非常感谢您的帮助。

4

1 回答 1

0

@user.name 打印 User 因为 .where("users.id = ?", params[:id]) 仍然返回一个数组

试试这个

@users = @search.where("users.id = ?", params[:id])
@user = @users.nil? ? @foundusers.first : @users.first
于 2011-07-26T17:07:27.943 回答