0

根据 solr 文档

以原子方式更新文档的核心功能要求架构中的所有字段都必须配置为已存储 (stored="true") 或 docValues (docValues="true"),但 <copyField/

必须存储 schema.xml 中的所有字段。我创建了两个核心 test_core_1 和 test_core_2。

这是test_core_1 架构

  <field name="_nest_path_" type="_nest_path_" stored="true"/>
  <field name="_root_" type="string"     indexed="true" stored="false"/>
  <field name="_version_" type="plong"  indexed="false" stored="false" docValues="true" useDocValuesAsStored="false" multiValued="false"/>
  <field name="id" type="string" multiValued="false" indexed="true" required="true" stored="true"/>
  <field name="sender" type="plong" docValues="true" indexed="true" stored="true" multiValued="false"/>
  <field name="text" type="text_general" uninvertible="false" omitNorms="false" indexed="true" stored="false" multiValued="false"/>
  <field name="name" type="text_general" uninvertible="true" omitNorms="false" indexed="true" stored="false" docValues="false" multiValued="false"/>  
  <field name="uniqueId" type="text_general" uninvertible="true" omitNorms="false" indexed="true" stored="true" multiValued="false"/>
  <field name="type" type="string" uninvertible="true" docValues="true" indexed="true" stored="false" useDocValuesAsStored="false" multiValued="false"/>
  <field name="value" type="string" uninvertible="true" docValues="true" indexed="true" stored="false" useDocValuesAsStored="false" multiValued="false" omitNorms="false"/>
  <field name="userId" type="plong" uninvertible="true" docValues="true" indexed="true" stored="false" useDocValuesAsStored="false" multiValued="false"/>

这是test_core_2 模式

<field name="_nest_path_" type="_nest_path_"/>
<field name="_root_" type="string" docValues="false" indexed="true" stored="false"/>
<field name="_version_" type="plong" indexed="false" stored="false"/>
<field name="id" type="string" multiValued="false" indexed="true" required="true" stored="true"/>
<field name="sender" type="plong" docValues="true" indexed="true" stored="true" multiValued="false"/>
<field name="text" type="text_general" uninvertible="false" omitNorms="false" indexed="true" stored="false" multiValued="false"/>
<field name="name" type="text_general" uninvertible="true" omitNorms="false" indexed="true" stored="false" docValues="false" multiValued="false"/>
<field name="uniqueId"  type="text_general" uninvertible="true" omitNorms="false" indexed="true" stored="true" multiValued="false"/>
<field name="type"  type="string" uninvertible="true" docValues="true" indexed="true" stored="false" useDocValuesAsStored="false" multiValued="false"/>
<field name="value" type="string" uninvertible="true" docValues="true" indexed="true" stored="false" useDocValuesAsStored="false" multiValued="false" omitNorms="false"/>
<field name="userId" type="plong" uninvertible="true" docValues="true" indexed="true" stored="false" useDocValuesAsStored="false" multiValued="false"/>

我可以只更新第一个核心 (test_core_1) 中的名称字段,但对于第二个核心,我得到了一个错误。

正如我们所看到的,我在两个核心的模式中都有非存储和非 docValues 字段,如name,差异与nest_pathversionroot相关。那么我怎么可能在第一个核心中更新名称(我的意思是更新部分文档或原子更新),但我从第二个核心得到了这个错误。

来自 http://localhost:8983/solr 的服务器错误:此架构不支持对嵌套文档的部分更新。请参阅参考指南。

根据文档,我必须从他们两个那里得到错误,我对 solr 中的这个主题感到困惑。谁能解释一下?

这是我的代码

SolrInputDocument document = new SolrInputDocument();
        document.setField("id", String.valueOf(id));
        document.setField("sender", id * 2);
        document.setField("text", "sampleText" + id);
        document.setField("name", "saba" + "safavi" + id);
        document.setField("uniqueId", "test" + id + DateUtil.getNowDate().getTime());
        List<Map<String, Object>> list = new ArrayList<>();
        Map<String, Object> obj;
        for (int i = 0; i < 10; i++) {
            obj = new HashMap<>();
            obj.put("type", "type" + i);
            obj.put("value", "value" + i);
            obj.put("userId", i);
            list.add(obj);
        }
        List<SolrInputDocument> metadataDocumentList = new ArrayList<>();
        for (Map<String, Object> stringObjectMap : list) {
            SolrInputDocument metadataDoc = new SolrInputDocument();
            for (Map.Entry<String, Object> stringObjectEntry : stringObjectMap.entrySet()) {
                metadataDoc.addField(stringObjectEntry.getKey(), stringObjectEntry.getValue());
            }
            metadataDocumentList.add(metadataDoc);
        }
        document.addField("meta", metadataDocumentList);
        try {
            UpdateResponse response = solrClient.add("test_core_2", document);
//            UpdateResponse response = solrClient.add("test_core_1", document);
            solrClient.commit("test_core_2");
//            solrClient.commit("test_core_1");
        } catch (SolrServerException | IOException e) {
            logger.error("error occured in add or update document solr.", e);
        }

SolrInputDocument solrDocument = new SolrInputDocument();
        solrDocument.addField("id", "20");
        Map<String, Object> fieldModifier = new HashMap<>();
        fieldModifier.put("set", "sabaNew20");
        solrDocument.addField("name", fieldModifier);
        try {
            UpdateResponse response = solrClient.add("test_core_1", solrDocument);
            solrClient.commit("test_core_1");
        } catch (SolrServerException | IOException e) {
            logger.error("error occurred in delete message #",e);
        }
4

0 回答 0