solr版本:8.x
1.准备下载中文分词器,下载分词器Maven Central Repository Search ,当下最新的没有solr8对应的分词器,另外solr也是自带分词器的,但本文并没有使用示例。
2.将下载好的jar包放入/solr-8.0.0/server/solr-webapp/webapp/WEB-INF/lib目录中。
3.修改/solr-8.0.0/server/solr/demo_core/conf/managed-schema,加入ik分词器配置(demo_core就是其他文章示例的核心,你应当换成自己的)
<!-- ik分词器 -->
<fieldType name="text_ik" class="solr.TextField">
<analyzer type="index">
<tokenizer class="org.wltea.analyzer.lucene.IKTokenizerFactory" useSmart="false" conf="ik.conf"/>
<filter class="solr.LowerCaseFilterFactory"/>
</analyzer>
<analyzer type="query">
<tokenizer class="org.wltea.analyzer.lucene.IKTokenizerFactory" useSmart="true" conf="ik.conf"/>
<filter class="solr.LowerCaseFilterFactory"/>
</analyzer>
</fieldType>
4.验证分词器:选中demo_core之后,Analysis菜单下,选text_ik的FieldType,输入中文内容,点击Analyse Values进行分词结果查看。
5.表结构中的某个字段需要分词的话,则需要设置type为text_ik,比如solr_demo表中name、address需要分词, 修改同目录/solr-8.0.0/server/solr/demo_core/conf/managed-schema
<!-- 映射数据库表结构的字段-->
<!-- <field name="name" type="string" indexed="true" stored="true" required="true" multiValued="false" /> -->
<!-- 需要中文分词,type设置为配置的txt_ik-->
<field name="name" type="text_ik" indexed="true" stored="true" required="true" multiValued="false" />
<field name="sex" type="string" indexed="true" stored="true" required="true" multiValued="false" />
<field name="address" type="text_ik" indexed="true" stored="true" required="true" multiValued="false" />
也就是将原来type=???改为type=text_ik,就能支持分词。
6.验证字段分词:选中demo_core之后,Analysis菜单下,q输入内容,点击Analyse Values进行结果查看