Solr搜索问题笔记(一)

2018-05-11 18:01:48 浏览数 (1)

笔记三个小问题: (1):使用solrj添加索引时,主要有两种方法, 第一种是直接使用solrinputDoucument的方法添加。 第二种是面向对象的形式将一份索引映射成一个Bean对象封装。 当使用第二种时,需要注意一个问题,如果一个对象里,有基本类型int,float,long,double等,那么建议使用其包装类型,why? 因为基本类型,在类实例化时候,是会初始化赋值的,这样一来,无论你添加的某条数据(Document)里,有没有这个field,那么它都会生成一个值为初始化的field,这样以来,在排序时候就可能会出现问题,比如按照某个成立日期升序,有些记录里的没有这个字的,而你又用了基本类型,那么添加到索引里面,就会出现一个成立日期为0的数据,这样以来,排序自然就排到了第一位,所以需要根据业务,进行适当调整。 引用类型的字段,如果为null,则此条记录不会生成filed (2):在排序时,对于那些没有值的field,我们应该如何控制其排序方式? 在Lucene里面,主要有两种方式, 第一,将丢失字段排在第一位。 第二,将丢失字段排在末尾。 对应到solr里面,支持String,Boolean,int,double,float,long类型缺失字段,排序方式,配置示例如下:

Java代码

  1. <!-- 缺失字段排最后一位 -->
  2. <fieldType name="string" class="solr.StrField" sortMissingLast="true" />
  3. <!-- 缺失字段排第一位 -->
  4. <fieldType name="boolean" class="solr.BoolField" sortMissingLast="false"/>

(3):如何在linux终端,执行curl命令清空某个core索引:

Java代码

  1. curl http://localhost:8983/solr/corename/update?commit=true -d '<delete><query>*:*</query></delete>'

0 人点赞