mac学习搭建solr8.x - db字段索引到solr增加中文分词

1.准备下载中文分词器,下载分词器http://search.maven.org/#search%7Cga%7C1%7Ccom.github.magese ,当下最新的没有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进行结果查看

猜你喜欢

转载自blog.csdn.net/csdn_avatar_2019/article/details/89405304
今日推荐