• solr 忽略大小写


    1、types标签下加入如下fieldType

    1. <fieldType name="str_lower" class="solr.TextField" sortMissingLast="true" omitNorms="true">
    2. <analyzer>
    3. <tokenizer class="solr.KeywordTokenizerFactory"/>
    4. <filter class="solr.LowerCaseFilterFactory" />
    5. </analyzer>
    6. </fieldType>

    2、fields标签下自定义field的type改为str_lower即可解决

    1. <field name="en_name" type="str_lower" indexed="true" stored="true"/>

    java调用传参不区分大小写,皆可查询到结果

    solr查询string类型时,有时需要使之不区分大小写( case insensitive),这时,就需要重新定义数据类型: 如统一转化为小写进行查询:

     
    1
    2
    3
    4
    5
    6
    7
    8
    <fieldType name="string_ci" class="solr.TextField"  sortMissingLast="true" omitNorms="true">
         <analyzer>
            <tokenizer class="solr.KeywordTokenizerFactory"/>          
            <filter class="solr.LowerCaseFilterFactory" />
         </analyzer>
     </fieldType>
     
    <field name="code" type="string_ci" indexed="true" stored="true" />


    因string类型为值是可不变的,因此此次使用TextField (string field type for fields that contain structured values that shouldn’t be altered in any way)
    注意:上面string_ci类型的field如果做facet时,得到的值将都是小写的,可能不符合实际需求。 因此,如果需要facet,需使用copyField再定义一个string类型的字段。 如:

     
    1
    2
    3
    <field name="code_cp" type="string" indexed="true" stored="false" />
     
     <copyField source="code" dest="code_cp"/>


    对code_cp进行facet则行。

    solr忽略大小写配置,在schema.xml中,对

    <filterclass="solr.xxxxx" ignoreCase="true"expand="true"/>

    中,对ignoreCase进行配置,如果为true,表示转化为小写匹配,及忽略大小写

  • 相关阅读:
    第九节 堆栈的概念和python代码实现
    第八节 单向循环链表简单介绍和python代码实现
    第七节 双向链表简单介绍和python代码实现
    第六节 单链表简单介绍和python代码实现
    第五节 顺序表的原理与python中的list类型
    第四节 抽象数据类型
    第三节 Python列表类型性能测试以及内置字典操作的时间复杂度分析
    第二节 大O表示法和时间复杂度
    MySQL优化指南
    Java类加载机制详解
  • 原文地址:https://www.cnblogs.com/cuihongyu3503319/p/9505148.html
Copyright © 2020-2023  润新知