SOLR可以执行UPSERT吗



我一直在尝试在solr中执行等效的UPSERT(如果已经存在,则插入或更新)。我只知道什么不起作用,我读过的solr/lucene文档也没有帮助。以下是我尝试过的:

curl 'localhost:8983/solr/update?commit=true' -H 'Content-type:application/json' -d '[{"id":"1","name":{"set":"steve"}}]'
{"responseHeader":{"status":409,"QTime":2},"error":{"msg":"Document not found for update.  id=1","code":409}}

我在一个请求中最多进行50次更新,并且请求可能包含具有独占字段的相同id(例如title_en和title_es)。如果有一种方法可以查询id列表是否存在,我可以拆分数据并执行单独的插入和更新命令。。。这是一个可以接受的替代方案,但是否已经有一个处理程序这样做了?在这一点上,我想避免做任何内部事务。

谢谢。

使用Solr 4.0,您可以对所有这些文档进行部分更新,只需更改字段即可保持整个文档不变。id应该匹配。

Solr不支持开箱即用的UPSERT机制。您可以创建记录,也可以更新记录,但语法不同。

如果更新记录,则必须确保所有其他预插入字段都已存储(而不仅仅是索引)。在封面下,更新会创建一个全新的记录,该记录只是预先填充了以前存储的值。但这种功能如果非常深入(可能在Lucene本身)。

你看过DataImportHandler吗?您颠倒了控制流(从Solr开始),但它确实支持检查哪些记录需要更新,哪些记录需要创建。

或者,您可以运行类似于的solr查询http://solr.example.com:8983/solr/select?q=id%3A(ID1+ID2+ID3)&fl=id&wt=csv您要求Solr查找您的ID记录,并只返回它找到的记录的ID。然后,您可以对其进行后期处理,以分割您的更新和插入。

最新更新