如果有人在搜索"apachesolr substring"之后到此为止,那么有一个更简单的解决方案:https://drupal.stackexchange.com/a/27956/10419 (来自https://drupal.stackexchange.com/questions/26024/how-can-i-make-search-with-a substring-of-a-word)
将ngramfilter添加到solr config目录中schema.xml中的文本类型定义.
<fieldType name="text" class="solr.TextField" positionIncrementGap="100">
<analyzer type="index">
<filter class="solr.EdgeNGramFilterFactory" minGramSize="3" maxGramSize="25" />
Run Code Online (Sandbox Code Playgroud)
您可以启用此功能,但它会非常消耗资源(例如搜索 SuffixQuery)。
请参阅:http ://lucene.472066.n3.nabble.com/Leading-Wildcard-Search-td522362.html
引用邮件列表: 解决方法吗?想象一下使用所有术语反向拼写的第二个索引(或添加另一个字段)。
=>
请参阅添加 ReverseStringFilter https://issues.apache.org/jira/browse/LUCENE-1398
并支持高效的前导通配符搜索:https ://issues.apache.org/jira/browse/SOLR-1321
目前 issues.apache.org 似乎已关闭。尝试使用例如谷歌缓存。