[英]tire elasticsearch kaminari pagination with overriden search in active record model
[英]Pagination with Elasticsearch, Tire, and Kaminari
我遇到了將搜索結果分頁以與Elasticsearch,Tire和Kaminari合作的問題。
我正在搜索我的應用程序中的所有模型(新聞,繪畫,書籍)作為一般網站搜索,因此,需要一個輪胎搜索塊,在我的站點控制器中進行更細粒度的控制,例如顯示超過默認值10個條目:
class SiteController < ApplicationController
def search
# @results = Painting.search(params[:query])
query = params[:query]
@results = Tire.search ['news','paintings', 'books'], :page => (params[:page]||1), :per_page=> (params[:per_page] || 3) do
query { string query }
size 100
end
end
end
在我的搜索結果頁面中,我有以下代碼:
- if @results
- @results.results.each do |result|
= result.title
#pagination
= paginate @results
在我的所有模型中,我有適當的映射,包括輪胎:
# - - - - - - - - - - - - - - - -
# Elasticsearch
# - - - - - - - - - - - - - - - -
include Tire::Model::Search
include Tire::Model::Callbacks
mapping do
indexes :id, index: :not_analyzed
indexes :title, boost: 100
indexes :slug, boost: 100, as: 'slug'
indexes :content
indexes :image, as: 'image.thumb.url'
indexes :tags, as: 'tags'
indexes :gallery_name, as: 'gallery.name'
indexes :created_at, :type => 'date'
end
我確保所有條目都在Elasticsearch中正確編入索引。
我遇到的問題是我無法讓它工作,最新的錯誤是:
未定義的方法`current_page'
任何想法將不勝感激。 謝謝。
你能試試這個??? 當我使用per_page選項時,我遇到了類似的問題。 所以,我轉向了輪胎提供的尺寸選項。 我不確定出了什么問題。 但是,明確設置和使用from和size對我來說是個竅門......
class SiteController < ApplicationController
def search
# @results = Painting.search(params[:query])
options = { :page => (params[:page] || 1), :size => 100 }
query = params[:query]
@results = Tire.search ['news','paintings', 'books'], options do
query { string query }
from options[:size].to_i * (options[:page].to_i-1)
end
end
end
Tire有包含在其lib中的Will-paginate gem的方法,所以我更喜歡它而不是Kaminari gem。 如果在任何情況下你仍然想和Kaminari在一起,請收集輪胎搜索的結果。
@results = @results.all.to_hash
paginate @results
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.