gpt4 book ai didi

ruby-on-rails - 重新轮胎 Elasticsearch 多表/索引搜索

转载 作者:行者123 更新时间:2023-12-02 23:37:02 24 4
gpt4 key购买 nike

我试图弄清楚用elastic.co进行多表搜索的最佳方法是什么。

特别是,我想知道是否可以向此搜索方法添加更多索引。

Chapter.rb

def self.search(params)
fields = [:title, :description, :content ]
**tables** = [Chapter.index_name, Book.index_name]
tire.search(**tables**, {load: true,page: params[:page], per_page: 5}) do
query do
boolean do
must { string params[:q], default_operator: "AND" } if params[:q].present?
end
end

highlight *fields, :options => { :tag => '<strong>' }
end

上面的示例在没有 的情况下有效。如何使其与表一起使用?

最佳答案

如果要添加更多索引,那么您将远离以模型为中心的搜索。这可能很好,因为我猜您由于来自不同索引而对搜索结果的处理方式会有所不同。

在这种情况下,我认为您可以:

Tire.search([Chapter.index_name, Book.index_name], 
page: params[:page],
... etc ...
) do
query do
... etc ...
end
end

这确实意味着您将无法执行 load: true之类的操作,因为您已经不知道要为结果加载哪种模型。

通过深入研究代码( here),即使对于以模型为中心的搜索,您似乎也可以指定多个索引。就像是:
tire.search({
index: [Chapter.index_name, Book.index_name],
load: true,
... etc ...

我还没有尝试过,但是我怀疑它是否会工作-同样是因为一旦涉及多个索引,就无法将结果加载到特定模型中。

关于ruby-on-rails - 重新轮胎 Elasticsearch 多表/索引搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29752945/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com