0

我正在尝试创建一个可以检索信息的表单。到目前为止,我已经实现了一个模型和一个带有动作查询的控制器。

这是表格:

<%= form_tag "/search", :method => "get" do %>
  <%= text_field_tag :query, params[:query] %>
  <%= submit_tag "Search", :name => nil %>
<% end %>

我的控制器有:

def query @results = Search.search(params[:query] ) end

在我的模型中,我有:

def self.search(search)
  if search
    Customer.find(:all, :conditions => ['first LIKE ?', "%#{search}%"])
  else
    Customer.find(:all)
  end
end

但它给了我以下错误:

ActiveRecord::StatementInvalid in SearchesController#query

SQLite3::SQLException: no such column: first: SELECT "customers".* FROM "customers"  WHERE (first LIKE '%test%')

为什么我的代码会产生此错误?

4

2 回答 2

0

尝试这个

Customer.find(:all, :conditions => ["'first' LIKE ?", "%#{search}%"])
于 2012-08-09T14:25:28.477 回答
0

这可能是因为您在数据库的客户表中没有第一列。

你的意思是 first_name 吗?

于 2012-08-09T14:24:01.870 回答