Мне нужно разделить мой индекс SOLR на две половины. Как оказалось, у меня уже есть поле STRING, которое представляет информацию о разделении, которая мне нужна. Это означает, что один вид записи, который будет искать, - это то, где строковое поле присутствует в записи и содержит значение, другой тип - это то, где оно не содержит значения. Все запросы должны указывать раздел для поиска. Теперь мне было бы быстрее искать это поле, используя запрос отрицательного поля, например -strFld:[* TO *]
, или мне было бы лучше / быстрее создать новое логическое поле, назвать его «hasStrFld» и выполнить поиск по нему? Таким образом, когда strFld отсутствует, hasStrFld имеет значение false. Аналогично, если в StrFld есть данные, тогда hasStrFld имеет значение true.
Другие соображения: существует очень низкая вероятность того, что в будущем индекс может быть разделен на третий раздел, что делает логические неприемлемые и отрицательные запросы непригодными, а также учитывает поле с перечисляемыми значениями. Тем не менее, вероятность довольно низкая, а высокая производительность сегодня намного важнее, чем возможность расширения на завтра.