我有一个相当简单的需求,需要在 Solr 中进行条件更新,这在 MySQL 中很容易完成。
例如,
- 我有 100 个文档,其中有一个名为
<id>
- 我正在发布 10 个文档,其中一些可能是重复的
<id>
s,在这种情况下,Solr 将使用相同的内容更新现有记录<id>
s
- 我有一个名为
<dateCreated>
我只想更新一个<doc>
如果新的<dateCreated>
大于旧的<dateCreated>
(这适用于重复的<id>
当然,仅限于此)
我怎样才能完成这样的事情呢?
上下文试图对抗竞争条件,导致同一 ID 多次添加,但执行顺序错误。
Thanks.
我可以想到两种方法:
- 写你自己的
UpdateHandler
并覆盖addDoc来实施该检查。
- 在客户端代码中放置适当的锁(关键部分),以便获取存储的文档、比较日期并以线程安全的方式有条件地添加新文档。
请记住,Solr 不是数据库,将其与 MySQL 进行比较就像比较苹果和橘子。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)