设为首页 收藏本站
查看: 918|回复: 0

[经验分享] solr通过单个fieldtype在document中创建多个field

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-12-16 10:59:00 | 显示全部楼层 |阅读模式
          在现有的终搜框架之下如果业务方需要在document文档中设置multivalued的属性,例如淘宝房产有这样的需求,每一个房产小区,都有不同面积的户型,比如有40方、60、90、150方的户型。 在实际使用中查询列表页面会根据户型的大小给所有小区的在售房源分类,比如:会查询有40方房子的小区,或者有60方房子的户型,或者查询有50至100方房源的楼盘。

        做之前可以先和业务方协定好存放多值字段在dump文件中的格式,比如可以使用逗号分隔(用啥分隔无所谓只要能识别就行了),淘宝房产的多值字段名字是roomSize,dump源文件中的内容可以是 40,50,60,150这样的字段内容。


  • 首先要在schema.xml配置文件中设置:
    <fieldType name="multi_tint"   class="com.taobao.terminator.s4fanglist.MultiValuedIntField"    precisionStep="8" omitNorms="true" positionIncrementGap="0"/>
    <field name="roomsSize"      
    type="multi_tint"    indexed="true"  stored="true"     multiValued="true"/>
  • 然后写一个TrieIntField类的扩展类,这里使用的是solr.1版本,4.0以下的版本类钩会有点区别 
    package com.taobao.terminator.s4fanglist;
    import org.apache.commons.logging.Log;
    import org.apache.commons.logging.LogFactory;
    import org.apache.lucene.index.IndexableField;
    import org.apache.solr.schema.SchemaField;
    import org.apache.solr.schema.TrieIntField;
    /**
    * @author 百岁(baisui@taobao.com)
    * @date 2013-6-13
    */
    public class MultiValuedIntField extends TrieIntField {
    private static final Log log = LogFactory.getLog(MultiValuedIntField.class);
    @Override
    public IndexableField[] createFields(SchemaField field, Object value,
    float boost) {
    if (value == null) {
    return super.createFields(field, value, boost);
    }
    String[] intValues = String.valueOf(value).split(",");
    log.info("raw valule :" + value + " has been split to "
    + intValues.length + " piece");
    IndexableField[] fields = new IndexableField[intValues.length];
    int i = 0;
    for (String val : intValues) {
    fields[i++] = this.createField(field, val, boost);
    }
    return fields;
    }
    //需要覆写isPolyFiled方法,只有这样DocumentBuilder类的addField 在执行的时候才会通过单个fieldtype在document构建出多个field来
    @Override
    public boolean isPolyField() {
    return isMultiValued();
    }
    }

  以上代码需要覆写isPolyFiled方法,只有这样DocumentBuilder类的addField 在执行的时候才会通过单个fieldtype在document构建出多个field来

以下是DocumentBuilder类的addField方法,供参考:

private static void addField(Document doc, SchemaField field, Object val, float boost) {
if (field.isPolyField()) {
IndexableField[] farr = field.getType().createFields(field, val, boost);
for (IndexableField f : farr) {
if (f != null) doc.add(f); // null fields are not added
}
} else {
IndexableField f = field.createField(val, boost);
if (f != null) doc.add(f); // null fields are not added
}
}
 将以上代码打包部署到服务端,就可以对roomSize字段进行查询了,查询方法和单值字段相同,例如可以使用


  roomSize:40 来查询有40平方面积的户型的楼盘,可以使用roomSize:[40 TO 60] 来查询有40到60方之内户型的楼盘。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-315115-1-1.html 上篇帖子: 2012-08-21 08:56 Solr Highlight 参数说明 下篇帖子: 基于jar搭建solr平台错误java.lang.NoClassDefFoundError: org/apache/lucene/search/spell/Ja
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表