gpt4 book ai didi

ruby-on-rails - 在 Rails 中使用 elasticsearch-model 保存特定字段

转载 作者:行者123 更新时间:2023-12-03 02:07:57 29 4
gpt4 key购买 nike

我在 Rails 4 项目中使用 elasticsearch-model gem 将我的用户存储在 MySQL 和 Elasticsearch 中。在我的项目中,Elasticsearch 部分用于查找具有某些 MySQL 字段(如 geo_point、birthdate、gender 等)的人……但并不是我在 MySQL“用户”表中的每个字段都对用户搜索有用。

所以,我想将所有用户字段存储在 MySQL 中,并且只存储用户在 Elasticsearch 中搜索所需的字段。

为了在创建时只存储必填字段,我重写了方法“as_indexed_json”并使用了:

as_json(only: ['id', 'gender', 'location']

在创建时,一切都很好。但是,当我使用应该只保存在 MySQL 中的字段来更新用户时,无论如何它都会将其添加到 Elasticsearch 中。

例如,我的用户模型有“id”、“gender”、“is_premium”、“status”、“created_at”、“birthdate”、“location”。
在 Elasticsearch 中,我只想保存“id”、“gender”、“birthdate”、“location”

我怎样才能做到这一点?
谢谢你的帮助。

最佳答案

这是 elasticsearch-rails 的一个问题(参见 github )。

简而言之,默认更新回调调用 update_document不使用 as_indexed_json : 它使用 ActiveModel::Dirty仅发送更改的列。

您可以通过覆盖 update_document 来解决此问题。方法,使其仅包含您想要的内容,或者通过更改回调的功能,例如

after_commit on: [:create, :update] do
index_document
end

after_commit on: [:destroy] do
delete_document
end

而不是使用默认的回调模块将导致 index_document被使用,它总是做一个“愚蠢的”完整更新,而不是试图只发送增量。

关于ruby-on-rails - 在 Rails 中使用 elasticsearch-model 保存特定字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23059812/

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