solr的multivalued使用说明

http://blog.csdn.net/alen1985/article/details/8538942

       solr的schema.xml配置文件在配置Filed的时候,有个属性:

       MutiValued:true if this field may containmutiple values per documents,这个说明有点模糊,下面结合实际应用,列举两个不同的例子

       例子一:一个field有多个值,值来自同一filed

  1. <fields> 
  2. <!-- general --> 
  3. <field name="id"      type="int"      indexed="true"  stored="true"  multiValued="false" required="true"/> 
  4. <field name="planTime"    type="tdate"   indexed="true"  stored="false"  multiValued="false" /> 
  5. <field name="state"   type="string"   indexed="true"  stored="false"  multiValued="false" /> 
  6. <field name="overDate"   type="string"   indexed="true"  stored="false"  multiValued="false" /> 
  7. <field name="type"   type="int"   indexed="true"  stored="false"  multiValued="false" /> 
  8. <field name="contactName"   type="textComplex"   indexed="true"  stored="false"  multiValued="false" /> 
  9. <field name="contactTel"    type="string"   indexed="true"  stored="false"  multiValued="false" /> 
  10. <field name="customer"    type="textComplex"   indexed="true"  stored="false"  multiValued="false" /> 
  11. <field name="alias"    type="textComplex"   indexed="true"  stored="false"  multiValued="false" /> 
  12. <field name="englishName"    type="textComplex"   indexed="true"  stored="false"  multiValued="false" /> 
  13. <field name="executor"    type="int"   indexed="true"  stored="true"  multiValued="true" /> 
  14. <!--[1m~K[1m~][1m~W段--> 
  15. <field name="keywords" type="text" indexed="true" stored="false" multiValued="true"/> 
  16. lt;/fields> 
 <fields>
  <!-- general -->
  <field name="id"      type="int"      indexed="true"  stored="true"  multiValued="false" required="true"/>
  <field name="planTime"    type="tdate"   indexed="true"  stored="false"  multiValued="false" />
  <field name="state"   type="string"   indexed="true"  stored="false"  multiValued="false" />
  <field name="overDate"   type="string"   indexed="true"  stored="false"  multiValued="false" />
  <field name="type"   type="int"   indexed="true"  stored="false"  multiValued="false" />
  <field name="contactName"   type="textComplex"   indexed="true"  stored="false"  multiValued="false" />
  <field name="contactTel"    type="string"   indexed="true"  stored="false"  multiValued="false" />
  <field name="customer"    type="textComplex"   indexed="true"  stored="false"  multiValued="false" />
  <field name="alias"    type="textComplex"   indexed="true"  stored="false"  multiValued="false" />
  <field name="englishName"    type="textComplex"   indexed="true"  stored="false"  multiValued="false" />
  <field name="executor"    type="int"   indexed="true"  stored="true"  multiValued="true" />
  <!--[1m~K[1m~][1m~W段-->
  <field name="keywords" type="text" indexed="true" stored="false" multiValued="true"/>
</fields>
     其中:
  1. <field name="executor"    type="int"   indexed="true"  stored="true"  multiValued="true"
  <field name="executor"    type="int"   indexed="true"  stored="true"  multiValued="true" /

    最后看下查询效果:

   

      从上图看书,executor这个field可以多个值,任何executor:29 OR executor:40,类似查询都能查出id为3的记录

     附注:使用solrj建此索引时,定义成集合类型即可如:

  1. @Field 
  2. private Set<Integer> executor; 
  3.  
  4. public Set<Integer> getExecutor() { 
  5.     return executor; 
  6.  
  7. public void setExecutor(Set<Integer> executor) { 
  8.     this.executor = executor; 
    @Field
    private Set<Integer> executor;

    public Set<Integer> getExecutor() {
        return executor;
    }

    public void setExecutor(Set<Integer> executor) {
        this.executor = executor;
    }
      

       例子二:类似综合搜索,结合copyFiled使用,多个Filed拷贝到该Field上

      

         从上图看出keywords区域,是name、introduction、industryName三个的集合,无论搜索name、introduction、industryName中任意一个,都能通过keywords搜索出来。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值