如何解决Searchkick / Elasticsearch 错误:请改用关键字字段或者,在 [name]
我在 Rails 应用中使用 Searchkick。我正在清理我的测试,我得到了一个基本的索引页面:
Searchkick::InvalidQueryError: [400] {"error":{"root_cause":[{"type":"illegal_argument_exception","reason":"Text fields are not optimised for operations that require per-document field data like aggregations and sorting,so these operations are disabled by default. Please use a keyword field instead. Alternatively,set fielddata=true on [name] in order to load field data by uninverting the inverted index.
我的模型(我添加了多租户的复杂性并尝试了所有这些我找到的可能解决方案的自定义映射):
class vendor < ApplicationRecord
multi_tenant :company
searchkick merge_mappings: true,inheritance: true,index_name: -> { [MultiTenant.current_tenant.tenant_name,model_name.plural,Rails.env].join('_') },mappings: {
properties: {
name: {
type: "text",fielddata: true,fields: {
keyword: {
type: "keyword"
}
}
}
}
}
def search_data
attributes.merge({
tracker: tracker_id,status: aasm_state,comments: comments.map(&:note).join(" "),city_es: city.presence ? city : "None",province_es: province.presence ? province : "None"
})
end
我的控制器(es_
方法是我在设置这些重复参数值时添加的一些自定义助手):
@vendors = vendor.search(es_query(),limit: es_limit(),aggs: { status: {},city_es: {},province_es: {} },where: where,offset: es_offset(),order: { es_order_col("name") => { order: es_order_dir(),unmapped_type: "long" }},match: :word,operator: "or",includes: [])
浏览器开发环境运行良好。不知道我在这里缺少什么来解决这个问题。
解决方法
一旦我添加了赏金,我就会弄清楚。我需要将 Vendor.reindex
添加到我的测试助手中。通常 minitest 会用一个单独的错误来抱怨这个,作为一个很好的提醒。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。