Solr: QueryElevationComponent требует ошибки StrField uniqueKeyField - PullRequest
6 голосов
/ 03 сентября 2010

Я недавно установил Solr. Пример индекса (находится в apache-solr - #. #. # \ Example \ solr), похоже, работает, и, скопировав его в домашнюю директорию solr, я могу получить к нему доступ через страницы администратора. Однако, когда я пытаюсь реализовать новый индекс, заменив содержимое schema.xml на (взято из здесь ):

<?xml version="1.0" encoding="UTF-8" ?> 
  <schema name="example" version="1.2">
  <types>
      <fieldType name="string" class="solr.StrField" sortMissingLast="true" omitNorms="true" /> 
      <fieldType name="int" class="solr.TrieIntField" precisionStep="0" omitNorms="true" positionIncrementGap="0" /> 
      <fieldType name="date" class="solr.TrieDateField" omitNorms="true" precisionStep="0" positionIncrementGap="0" /> 
      <fieldType name="text" class="solr.TextField" positionIncrementGap="100">
          <analyzer type="index">
              <tokenizer class="solr.WhitespaceTokenizerFactory" /> 
              <filter class="solr.StopFilterFactory" ignoreCase="true" words="stopwords.txt" enablePositionIncrements="true" /> 
              <filter class="solr.WordDelimiterFilterFactory" generateWordParts="1" generateNumberParts="1" catenateWords="1" catenateNumbers="1" catenateAll="0" splitOnCaseChange="1" /> 
              <filter class="solr.LowerCaseFilterFactory" /> 
              <filter class="solr.SnowballPorterFilterFactory" language="English" protected="protwords.txt" /> 
          </analyzer>
        <analyzer type="query">
          <tokenizer class="solr.WhitespaceTokenizerFactory" /> 
          <filter class="solr.SynonymFilterFactory" synonyms="synonyms.txt" ignoreCase="true" expand="true" /> 
          <filter class="solr.StopFilterFactory" ignoreCase="true" words="stopwords.txt" enablePositionIncrements="true" /> 
          <filter class="solr.WordDelimiterFilterFactory" generateWordParts="1" generateNumberParts="1" catenateWords="0" catenateNumbers="0" catenateAll="0" splitOnCaseChange="1" /> 
          <filter class="solr.LowerCaseFilterFactory" /> 
          <filter class="solr.SnowballPorterFilterFactory" language="English" protected="protwords.txt" /> 
        </analyzer>
      </fieldType>
      </types>
  <fields>
      <field name="fileid" type="int" indexed="true" stored="true" required="true" /> 
      <field name="doctext" type="text" indexed="true" stored="false" required="false" /> 
      <field name="title" type="text" indexed="true" stored="false" required="false" /> 
      <field name="datecreated" type="date" indexed="true" stored="false" /> 
  </fields>
  <uniqueKey>fileid</uniqueKey> 
  <defaultSearchField>doctext</defaultSearchField> 
  <solrQueryParser defaultOperator="OR" /> 
  </schema>

Я получаю сообщение об ошибке конфигурации, которое, по-видимому, говорит о том, что uniqueKeyField должен быть реализован с типом StrField (что-то, во что я не могу поверить, действительно имеет место?)):

"HTTP Status 500 - Серьезные ошибки в конфигурации solr. ... org.apache.solr.common.SolrException: QueryElevationComponent требует, чтобы в схеме был реализован uniqueKeyField с использованием StrField в org.apache.solr.handler. component.QueryElevationComponent.inform (QueryElevationComponent.java:157) в org.apache.solr.core.SolrResourceLoader.inform (SolrResourceLoader.java:508) в ... "

Мой поиск в Google оказался очень небольшим, чтобы помочь, поэтому я надеюсь, что здесь есть кто-то, кто мог бы столкнуться с этой проблемой и / или иметь какие-то идеи, как решить ее?

Заранее спасибо за любой совет, Беа.

Ответы [ 2 ]

11 голосов
/ 03 сентября 2010

Да, в данный момент QueryElevationComponent требует строковый уникальный ключ.Это ограничение задокументировано в вики Solr .

Вот проблема в проекте JIRA.

0 голосов
/ 02 марта 2011

Если вы все еще ищете ответ,

В файле schema.xml включите следующее

<fieldType name="uuid" class="solr.UUIDField" indexed="true" /> 
<field name="id" type="uuid" indexed="true" stored="true" default="NEW" /> 

.результат наилучшей ставки.

<elevate>
 <query text="foo bar">
  <doc id="4602376f-9741-407b-896e-645ec3ead457" />
 </query>
</elevate>

Здесь 4602376f-9741-407b-896e-645ec3ead457 - это значение в поле «id» документа наилучшей ставки.Желательно, чтобы Solr позволял нам указывать любое поле первичного ключа, например employeeid или productid для указания в elevate.xml

...