首先,讲解一下/usr/local/solr/collection1/conf/schema.xml的配置,此文档功能相似于配置索引数据库。数据库
Field:相似于数据库字段的属性(此文统一使用用“字段”描述它),请看一条fieldapache
<field name="user" type="string" indexed="true" stored="true" multiValued="true" />
name:当前字段名 type:当前字段使用的分词类型(在schemal.xml文件的fieldType中进行配置) indexed:当前字段进行索引(当用户查询时能够使用到该字段) stored:当前字段进行存储(当用户查询到该字段时,能返回字段的原文) multiValued:当前字段可存在多个值(如:user字段可存储多个用户)svn
fieldType:字段处理,此类节点能够配置各类数据类型的处理方式,如:分词,过滤测试
<fieldType name="textComplex" class="solr.TextField"> <analyzer> <tokenizer class="com.chenlb.mmseg4j.solr.MMSegTokenizerFactory" mode="complex" dicPath="/usr/local/solr/dic"/> </analyzer> </fieldType>
copyField:当添加一条索引时,可将source字段的值复制到dest字段上去,可设置多个source字段指向同一个dest字段,这样对dest进行索引的话,能够查询到全部source字段的索引。this
如:在一个新闻系统中,将标题,内容复制到一个统一的字段,这样搜索all字段时,只要title,content中任意存在就能被搜索到。spa
<copyField source="title" dest="all"/> <copyField source="content" dest="all"/>
OK,此文档配置成功后,接下来能够添加一条索引试试效果,在solr的后台管理界面能够直接添加索引,并作查询,分析测试。code
solr为咱们准备了一些文档添加实例,能够参考一下:http://svn.apache.org/repos/asf/lucene/dev/trunk/solr/example/exampledocs/xml
<add> <doc> <field name="employeeId">05991</field> <field name="office">Bridgewater</field> <field name="skills">Perl</field> <field name="skills">Java</field> </doc> [<doc> ... </doc>[<doc> ... </doc>]] </add>
此配置文档还有两个重要的配置节点blog
<uniqueKey>节点用于配置主键,跟数据库主键功能相似,主要用于标示一条数据,当要删除一条数据时能够用该值精肯定位,当添加数据主键重复时可设置是覆盖,仍是更新。索引
<uniqueKey>clipId</uniqueKey>
<defaultSearchField>节点用于配置查询默认字段,当查询数据时,未指定具体查询字段,将使用该默认字段。
<defaultSearchField>_all</defaultSearchField>