[英]Rails 3 taking a long time to load the results
我的Rails应用程序必须通过缺少行的数据库查询并显示匹配的结果。 我的代码运行正常,但运行缓慢,显示结果花费了很长时间。我使用的是ruby 1.9.3,rails 3.2.13和“ Webrick”服务器。我肯定有问题。 有什么办法可以解决这个问题?我有两个表分别称为坐标和推文。
我的控制器代码
require 'will_paginate/array'
class TweetsController<ApplicationController
def index
city = params[:show]
search_term = params[:text]
search_term.gsub!(/\s/, '%')
city_coordinates = Coordinates.where('city=?', city)
if (city_coordinates.count == 1 && city_coordinates.first.valid_location?)
@tweets = ((Tweets.for_coordinates(city_coordinates.first) & Tweets.where("tweet_text LIKE?" , "%#{search_term}%"))).paginate(page: params[:page], per_page:5)
elsif(city_coordinates.count!=1)
@tweets = ((Tweets.for_user_location(city) & Tweets.where("tweet_text LIKE?" , "%#{search_term}%"))).paginate(page: params[:page], per_page: 5)
else
Tweets.where("tweet_text LIKE? ", "%#{search_term}%").paginate(page: params[:page], per_page: 5)
end
end
end
我的模型代码
class Tweets<ActiveRecord::Base
attr_accessible :id, :tweet_created_at, :tweet_id, :tweet_text, :tweet_source, :user_id, :user_name, :user_sc_name, :user_loc, :user_img, :longitude, :latitude, :place, :country
def self.for_coordinates(coordinates)
bbox = { min_lat: coordinates.latitude - 1.0, max_lat: coordinates.latitude + 1.0,
min_lng: coordinates.longitude - 1.0, max_lng: coordinates.longitude + 1.0
}
Tweets.where("(longitude BETWEEN ? and ?) AND (latitude BETWEEN ? and ?) OR (user_loc LIKE ?) " ,
bbox[:min_lng], bbox[:max_lng], bbox[:min_lat], bbox[:max_lat], "%#{coordinates.city}%" )
end
def self.for_user_location(city)
@tweets= Tweets.where("user_loc LIKE ?", "%#{city}%")
end
end
我的视图代码
<%= will_paginate @tweets %>
<% @tweets.each do |tweets| %>
<ul>
<li><%= tweets.id %></li>
<li><%= tweets.tweet_created_at %></li>
<li><%= tweets.tweet_source %></li>
<li><%= tweets.tweet_text %></li>
<li><%= tweets.user_id %></li>
<li><%= tweets.user_name %></li>
<li><%= tweets.user_sc_name %></li>
<li><%= tweets.user_loc %></li>
<li><%= tweets.user_img %></li>
<li><%= tweets.longitude %></li>
<li><%= tweets.latitude %></li>
<li><%= tweets.place %></li>
<li><%= tweets.country %></li>
<% end %>
</ul>
它有两个搜索框,一个用于推文查询,另一个用于城市,它必须显示特定城市的推文。但是它非常慢。我无法找到原因是由于编码效率低下或选择错误导致的服务器或其他原因。它使用Mysql数据库。
您的问题是两个查询的并集:
@tweets = (
(
Tweets.for_coordinates(city_coordinates.first) &
Tweets.where("tweet_text LIKE?" , "%#{search_term}%")
)
).paginate(page: params[:page], per_page:5)
这是什么:
您要执行的操作是:
您将需要更多这样的东西:
@tweets = Tweets.for_coordinates(city_coordinates.first).
where('tweet_text like ?', "%#{search_term}%").
paginate(page:params[:page], per_page:5)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.