solr配置业务字段
转载自:https://blog.****.net/u014695188/article/details/51227476
1、在solr中默认是没有中文分析器,需要手工配置。配置一个FieldType,在FieldType中指定中文分析器。
2、Solr中的字段必须是先定义后使用。
1.1 中文分析器的配置
第一步:使用IK-Analyzer。把分析器的文件夹上传到服务器。
第二步:需要把分析器的jar包添加到solr工程中。
cd IK\ Analyzer\ 2012FF_hf1/cp IKAnalyzer2012FF_u1.jar /usr/local/solr/tomcat/webapps/solr/WEB-INF/lib/
第三步:需要把IKAnalyzer需要的扩展词典及停用词词典、配置文件复制到solr工程的classpath。
/usr/local/solr/tomcat/webapps/solr/WEB-INF/classes
cp IKAnalyzer.cfg.xml ext_stopword.dic mydict.dic/usr/local/solr/tomcat/webapps/solr/WEB-INF/classes
注意:扩展词典及停用词词典的字符集必须是utf-8。不能使用windows记事本编辑。
第四步:配置fieldType。需要在solrhome/collection1/conf/schema.xml中配置。
技巧:使用vi、vim跳转到文档开头gg。跳转到文档末尾:G
按 G 跳转到文档末尾
添加
- <fieldType name="text_ik" class="solr.TextField">
- <analyzer class="org.wltea.analyzer.lucene.IKAnalyzer"/>
- </fieldType><span style="font-family:Arial, Helvetica, sans-serif;"><span style="white-space: normal;">
- </span></span>
2.2 业务字段配置
业务字段判断标准:
1、在搜索时是否需要在此字段上进行搜索。例如:商品名称、商品的卖点、商品的描述
2、后续的业务是否需要用到此字段。例如:商品id。
如 需要用到的字段:
1、商品id
2、商品title
3、卖点
4、价格
5、商品图片
6、商品分类名称
7、商品描述
Solr中的业务字段:solrhome/collection1/conf/schema.xml中添加
1、id——》商品id
其他的对应字段创建solr的字段。
- <field name="item_title" type="text_ik" indexed="true" stored="true"/>
- <field name="item_sell_point" type="text_ik" indexed="true" stored="true"/>
- <field name="item_price" type="long" indexed="true" stored="true"/>
- <field name="item_image" type="string" indexed="false" stored="true" />
- <field name="item_category_name" type="string" indexed="true" stored="true" />
- <field name="item_desc" type="text_ik" indexed="true" stored="false" />
- <field name="item_keywords" type="text_ik" indexed="true" stored="false" multiValued="true"/>
- <copyField source="item_title" dest="item_keywords"/>
- <copyField source="item_sell_point" dest="item_keywords"/>
- <copyField source="item_category_name" dest="item_keywords"/>
- <copyField source="item_desc" dest="item_keywords"/>
重启tomcat
3.1 维护索引库
添加:添加一个json格式的文件就可以。
修改:在solr中没有update,只需要添加一个新的文档,要求文档id和被修改文档的id一致。原理是先删除后添加。
删除:使用xml格式。
删除两种方法:
1、根据id删除:
<delete>
<id>test001</id>
</delete>
<commit/>
2、根据查询删除:
<delete>
<query>*:*</query>
</delete>
<commit/>