Solr的基本使用

来源:互联网 发布:jquery.checktree.js 编辑:程序博客网 时间:2024/06/06 14:11

Solr的基本使用

1.1 Schema.xml

schema.xml文件中主要配置了solrcore的一些数据信息包括FieldFieldType的定义等信息solrFieldFieldType都需要先定义后使用

 

 

 1.1.1 Filed

定义Field

 <field name="id" type="string" indexed="true" stored="true" required="true" multiValued="false" />

 Name:指定域的名称

Type:指定域的类型

Indexed:是否索引

Stored:是否存储

Required:是否必须

multiValued:是否多值比如商品信息中一个商品有多张图片,一个Field像存储多个值的话,必须将multiValued设置为true

 1.1.2 dynamicField

动态域

<dynamicField name="*_i"  type="int"    indexed="true"  stored="true"/>

 Name:指定动态域的命名规则

 1.1.3 uniqueKey

指定唯一键

 <uniqueKey>id</uniqueKey>

 其中的id是在Field标签中已经定义好的域名,而且该域要设置为requiredtrue

 一个schema.xml文件中必须有且仅有一个唯一键

1.1.4 copyField

复制域

 <copyField source="cat" dest="text"/>

 Source:要复制的源域的域名

Dest:目标域的域名

 

dest指的的目标域,必须设置multiValuedtrue

 

 

 1.5 FieldType

定义域的类型

 

<fieldType name="text_general" class="solr.TextField" positionIncrementGap="100">

      <analyzer type="index">

        <tokenizer class="solr.StandardTokenizerFactory"/>

        <filter class="solr.StopFilterFactory" ignoreCase="true" words="stopwords.txt" />

        <!-- in this example, we will only use synonyms at query time

        <filter class="solr.SynonymFilterFactory" synonyms="index_synonyms.txt" ignoreCase="true" expand="false"/>

        -->

        <filter class="solr.LowerCaseFilterFactory"/>

      </analyzer>

      <analyzer type="query">

        <tokenizer class="solr.StandardTokenizerFactory"/>

        <filter class="solr.StopFilterFactory" ignoreCase="true" words="stopwords.txt" />

        <filter class="solr.SynonymFilterFactory" synonyms="synonyms.txt" ignoreCase="true" expand="true"/>

        <filter class="solr.LowerCaseFilterFactory"/>

      </analyzer>

    </fieldType>

Name:指定域类型的名称

Class:指定该域类型对应的solr的类型

Analyzer:指定分析器

Type:index、query,分别指定搜索和索引时的分析器

Tokenizer:指定分词器

Filter:指定过滤器