首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何实现Solr自定义评分查询

(一)背景介绍 大多数时候我们使用lucene/solr/elasticsearch自带的评分查询都是没问题的,当然这也仅仅限于简单的业务或者对搜索排名 不敏感的场景中,假设业务方要求有若干业务因子要干扰到排名...(二)实现策略 (1)在索引的时候把众多的业务评分计算提前计算好,存储成一个字段,然后查询的时候根据这个字段排名。...solr中,实现开发自定义评分组件,solr基于lucene,总体来说 与lucene大同小异,需要自己开发几个包装的类即可,在elasticsearch中也是如此,后面有机会,再探讨在elasticsearch...(B)通过Function Query实现 函数查询一项强大的功能,solr已经自带了 许多的函数,比如数学函数,聚合函数等,详细资料可看官网的wiki资料 https://cwiki.apache.org...(四)总结 其实核心功能还是使用lucene实现的,solr/es则是在lucene的基础上提供了强大灵活的插件机制,这样以来,我们就能更容易实现一些我们特殊需求的定制化。

1.7K70
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    solr字段说明】Solr查询详解

    这节重点是讲Solr查询相关的知识点 一、 查询参数说明 在做solr查询的时候,solr提供了很多参数来扩展它自身的强大功能!以下是使用频率最高的一些参数! ...rows - 指定返回结果最多有多少条记录,配合start来实现分页。 ...hl.simple.pre 高亮前面的格式  hl.simple.post 高亮后面的格式  facet 是否启动统计  facet.field 统计field  【注:以上是比较常用的参数,当然具体的参数使用还是多看Solr...官方的技术文档以及一些大神的博文日志,这里只是抛砖引玉】 二、 Solr运算符 1. “:” 指定字段查指定值,如返回所有值*:* 2. “?”...:  修饰符 字段名:查询关键词 AND/OR/NOT 修饰符 字段名:查询关键词 三、 Solr查询语法 1.最普通的查询,比如查询姓张的人( Name:张),如果是精准性搜索相当于SQL SERVER

    2.2K30

    HBASE+Solr实现详单查询

    针对HBase的多条件查询也有多种方案,但是这些方案要么太复杂,要么效率太低,本文只对基于Solr的HBase多条件查询方案进行测试和验证。...原理 基于Solr的HBase多条件查询原理很简单,将HBase表中涉及条件过滤的字段和rowkey在Solr中建立索引,通过Solr的多条件查询快速获得符合过滤条件的rowkey值,拿到这些rowkey...wd代表用户write data写数据,从用户提交写数据请求wd1开始,经历wd2,写入MySQL数据库,或写入结构数据存储云中,wd3,提交到Solr集群中,从而依据业务需求创建索引。...rd代表用户read data读数据,从用户提交读数据请求rd1开始,经历rd2,直接读取MySQL中数据,或向Solr集群请求搜索服务,rd3,向Solr集群请求得到的搜索结果为ID,再向结构数据存储云中通过...实现方法有两种 手工编码,直接用HBASE的API,可以参考下文 http://www.cnblogs.com/chenz/articles/3229997.html 可以使用HBASE/Solr的LUNA

    2K50

    Solr如何使用游标进行深度分页查询

    ,所以在solr里面,分页并不适合深度分页。...使用游标的方式读取数据,也有一些约束或者缺点: (1)查询条件里面必须有cursorMark参数,而且必须不能有start参数 (2)查询的条件里必须按照主键排序(升序或降序),如果没有这个条件,主键重复...,那么会造成多个游标的mark值,这样以来下一次请求就不知道如何定位了,而且有可能出现重复读数据的情况 (3)如果一个分页的系统,按照指定页码跳转的功能,这样实现的功能是实现不了的,因为游标一旦读取了...solrj实现代码例子: //游标查询 public static void cursorQuery()throws Exception{ //http solr服务...HttpSolrClient sc=new HttpSolrClient("http://localhost:8983/solr/one"); //solr查询封装

    2.6K70

    MySQL 如何实现递归查询?「建议收藏」

    前言 最近在做的业务场景涉及到了数据库的递归查询。我们公司用的 Oracle ,众所周知,Oracle 自带有递归查询的功能,所以实现起来特别简单。...但是,我记得 MySQL 是没有递归查询功能的,那 MySQL 中应该怎么实现呢? 于是,就有了这篇文章。...函数 MySQL 自定义函数 手动实现 MySQL 递归查询 Oracle 递归查询 在 Oracle 中是通过 start with connect by prior 语法来实现递归查询的...MySQL 递归查询 可以看到,Oracle 实现递归查询非常的方便。但是,在 MySQL 中并没有帮我们处理,因此需要我们自己手动实现递归查询。...(这里没有用到 group by 分组字段,则可以认为只有一组) MySQL 自定义函数,实现递归查询 可以发现以上已经把字符串拼接的问题也解决了。那么,问题就变成怎样构造有递归关系的字符串了。

    11.5K10

    Solr如何使用游标进行深度分页查询

    ,所以在solr里面,分页并不适合深度分页。...使用游标的方式读取数据,也有一些约束或者缺点: (1)查询条件里面必须有cursorMark参数,而且必须不能有start参数 (2)查询的条件里必须按照主键排序(升序或降序),如果没有这个条件,...主键重复,那么会造成多个游标的mark值,这样以来下一次请求就不知道如何定位了,而且有可能出现重复读数据的情况 (3)如果一个分页的系统,按照指定页码跳转的功能,这样实现的功能是实现不了的,因为游标一旦读取了...solrj实现代码例子: Java代码 //游标查询 public static void cursorQuery()throws Exception{ //http solr服务...HttpSolrClient sc=new HttpSolrClient("http://localhost:8983/solr/one"); //solr查询封装

    3.3K60

    干货 | 如何Solr搭建大数据查询平台

    LTS 硬件配置: i7 4770k,16G DDR3,2T西数黑盘 2.1 mysql数据库 Mysql数据库的安装和配置我这里不再赘述,只提一点,对于社工库这种查询任务远远多于插入和更新的应用来说...Solr安装完成,现在我们需要从mysql导入数据,导入前,我们需要先创建一个core,core是solr的特有概念,每个core是一个查询、数据,、索引等的集合体,你可以把它想象成一个独立数据库,我们创建一个新...保存后,core的配置就算完成了,不过要导入mysql数据,我们还需要在mysql网站上下载mysql-connector-java-bin.jar库文件,连同solr-5.5.0/dist目录下面的...接下来就是漫长的等待…… 导入完成后,我们就可以开始查询了,solr查询全部使用post参数,比如: http://localhost:8983/solr/solr_mysql/select?...,mysql只负责存储整理好的数据,并不提供查询服务,整理和导入新数据库时,只需操作mysqlsolr利用自带的jetty独立运行,定期从mysql导入增量更新的数据,Tomcat作为应用服务器,运行提供查询

    4.6K70

    MySQL如何实现分库分表,如何提高查询效率

    1、如何分库分表? 两种解决方案:垂直拆分、水平拆分 垂直拆分:根据业务进行拆分,比如可以将一张表中的多个字段拆成两张表,一张是不经常更改的,一张是经常改的。...水平拆分:即根据表来进行分割:比如user表可以拆分为user0,、user1、user2、user3、user4等 2、分库分表之后如何实现联合查询?...可以使用第三方中间件来实现,比如:mycat、shading-jdbc 原理解析: 当客户端发送一条sql查询:select * from user;此时中间件会根据有几个子表,拆分成多个语句:select...* from user1;select * from user2;select * from user3等多条语句查询,然后将查询的结果返回给中间件,然后汇总给客户端。

    4.4K20

    Hbase+Solr实现二级索引提供高效查询

    接着上一篇介绍协处理器的文章http://qindongliang.iteye.com/blog/2277145,本篇我们来实战一个例子,看下如何使用协处理来给Hbase建立二级索引。...hbase-increment-index 业务需求: 现有一张Hbase的表,数据量千万级+,而且不断有新的数据插入,或者无效数据删除,每日新增大概几百万数据,现在已经有离线的hive映射hbase 提供离线查询...,但是由于性能比较低,且不支持全文检索,所以想提供一种OLAP实时在线分析的查询,并且支持常规的聚合统计和全文检索,性能在秒级别可接受 需求分析: hbase的目前的二级索引种类非常多,但大多数都不太稳定或成熟...技术实现 (1)搭建一套solr或者es集群,并且提前定制好schemal,本例中用的是solr单节点存储索引, 如果不知道怎么搭建solrcloud集群或者elasticsearch集群,请参考博客...解决办法: 使用solr的 httpclient-4.3.1.jar httpcore-4.3.jar 替换所有节点hbase/lib下的 低版本的httpclient组件包,即可!

    2.9K60

    Lucene+Solr+ElasticSearch查询匹配优化

    Apache Lucene这个强大的全文检索核心包,提供了搜索引擎的核心组件,通过相关性评分算法(VSM/BM25),出色的了解决了相关性匹配问题,当然Solr和ElasticSearch构建在Lucene...默认情况下,Lucene/Solr/ES的Boolean查询有三种查询策略: (1)必须匹配 -> must (2)必须不匹配 -> mustn't (3)至少匹配一个 ->should 除此之外...+mm=3 能查询到北京奇虎科技有限公司 情景2:查询北京奇虎360+mm=3 不能查询到北京奇虎科技有限公司 情景3:查询北京奇虎360+mm=2 能查询到北京奇虎科技有限公司 情景4:查询北京奇虎...: 对于分词后term数少的,适合采用固定数进行查询限制优化查询 对于分词后term数多的,适合采用百分比进行查询限制优化 mm=0% 代表最少匹配查询词里面出现的任意一个term mm=100%...参考资料: https://cwiki.apache.org/confluence/display/solr/The+DisMax+Query+Parser#TheDisMaxQueryParser-Themm

    1.3K50

    使用MySQL实现分页查询

    使用MySQL实现分页查询 本文关键字:MySQL、分页查询、真分页、假分页、LIMIT 在项目开发当中,经常要实现分页功能,在面试时也会经常被问到,什么是分页。...什么是分页 一般在客户端实现分页功能的时候,要显示当前页的数据、当前所在页数、临近页面的按钮以及总页数等等。...这些数据随着翻页的进行能够动态的变化,为了实现这样的效果,一般会采取两种办法:真分页和假分页。这样的划分方式是从与数据库的交互方式出发的,是每次翻页时都进行查询还是一次性查出所有的数据。 2....在对数据库中的数据进行修改后,要将变更后的数据及时同步到缓存层,在进行数据查询时从缓存层获取。 ? 二、MySQL实现分页 本文将介绍如何通过真分页的方式,每次取出所需数据。...对于不同的数据,实现分页有不同的方式,在MySQL中可以使用LIMIT来限制查询出的数据。 1. LIMIT用法 LIMIT出现在查询语句的最后,可以使用一个参数或两个参数来限制取出的数据。

    17.1K52

    Mysql实现树形递归查询

    最近在做项目迁移,Oracle版本的迁到Mysql版本,遇到有些oracle的函数,mysql并没有,所以就只好想自定义函数或者找到替换函数的方法进行改造。...Oracle递归查询 oracle实现递归查询的话,就可以使用start with … connect by connect by递归查询基本语法是: select 1 from 表格 start with...pid就是这条记录的根节点了 具体可以参考我以前写的一篇oracle方面的博客:https://cloud.tencent.com/developer/article/1384471 Oracle方面的实现...递归查询 下面主要介绍Mysql方面的实现Mysql并没有提供类似函数,所以只能通过自定义函数实现,网上很多这种资料,不过已经不知道那篇是原创了,这篇博客写的不错,https://www.2cto.com.../database/201209/152513.html, 下面我也是用作者提供的方法实现自己的,先感谢作者的分享 这里借用作者提供的自定义函数,再加上Find_in_set函数 find_in_set

    5.5K30
    领券