solr配置业务字段
转载自:https://blog.csdn.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/>

作者:阿T_smile
来源链接:https://blog.csdn.net/huangchunxia_1/article/details/79710786
版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。
2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。