我一定做错了什么。我有一个简单的搜索,它在开发中(使用sqlite3数据库)工作得很好,但在生产中(使用MYSQL数据库)工作不好。不确定如何调试。
以下是详细信息:
控制器:
def index
@search = Individual.search(params[:search])
@individuals = @search.all
# @individuals = @search.order(:lastname).page params[:page]
end
视图:
= form_for @search, :url => individuals_path, :html => {:method => :get} do |f|
%fieldset
%strong
= f.label :firstname_like, "First Name?"
= f.text_field :firstname_like
%strong
= f.label :lastname_like, "Last Name?"
= f.text_field :lastname_like
= f.submit "Search"
在生产环境中使用控制台没有问题:
Individual.search :lastname_like => 'Smith', :firstname_like => ''
=> #<MetaSearch::Searches::Individual:0blahblah....
只是无法通过浏览器工作。我得到了每一个人的回报。(无错误)
我想知道这是否与URL编码有关?
Started GET "/individuals/?utf8=%25E2%259C%2593&search%255Bfirstname_like%255D=& search%255Blastname_like%255D=hermans&commit=Search" for 68.87.23.92 at Thu May 26 09:22:31 -0700 2011
Processing by IndividualsController#index as HTML
Parameters: {"commit"=>"Search", "search%5Bfirstname_like%5D"=>"", "utf8"=>"%E2%9C%93", "search%5Blastname_like%5D"=>"smith"}
有什么想法吗?或者至少如何调试?
轨道3.0.7Metasearch 1.0.3
是的,我想这是url的问题。据我所知,它应该是这样的:
/individuals/?utf8=%E2%9C%93&search%5Bfirstname_like%5D=&search%5Blastname_like%5D=hermans&commit=Search
我不使用haml,所以我不能说发生了什么,但这是你的表单的问题。它在每个编码字符中添加了25。页面上的编码设置正确吗?
如果您在控制台上获得输出,那么您的函数工作正常。要进行调试,请尝试在每一步记录信息,看看哪里出了问题,例如,打印传递给搜索函数的参数,搜索返回的输出是什么,等等,看看事情进展如何。您还可以查看production.log中激发的数据库查询,并尝试从终端手动运行它,然后查看结果。
您甚至可以尝试在生产服务器上以开发模式运行应用程序,将database.yml更改为使用生产数据库和mysql,以查看这是否是特定于环境的问题。