solr特点三: 排序样例汇总

目的是提供solrj 实现 查询的样例参考

单维度排序

//查询条件

query.setQuery(queryString);

// add 是添加

query.addSortField(field_price, ORDER.asc);

//set是覆盖,也就是后面的覆盖前面的。

query.setSortField(field_price,ORDER.desc);

//如果需要第一维度值相等,按第二维度继续排序的话,继续add

query.addSortField(field_fans_count, ORDER.asc);

一般两个维度就可以了,也有定义第三个维度,就过去经验看,第三维度基本没起到区分效果。第一、二维度比较关键。

文本排序

// 查询条件 没有设定排序的,默认就是文本排序。文本的因子可以动态调整或者plugin的

query.setQuery("user_nick:淘宝女装");

离线得分排序

// 查询条件

query.setQuery("user_nick:淘宝女装");

//离线生成域field_service_value,里面保持复杂得分模型运算后的分值

query.addSortField(field_service_value,ORDER.desc);

boost查询排序

// 查询条件 表示命中nick的权重是2,而命中descr的权重是0.5,最终是二者求和

query.set("defType","lucene");

query.setQuery("(user_nick:淘宝女装)^2 OR (user_descr:淘宝女装)^0.5");

//查询条件,表示命中nick的权重2,命中descr权重0.5,最终那个大取那个

query.set("defType","dismax");

query.setQuery("淘宝女装");

query.add("qf","user_nick^2,user_descr^0.5");

function查询排序

//按照指定函数排序

query.set("q","user_nick:淘宝女装");

query.set("sort","sum(fans_count,1) desc");

文本和函数混合排序

//文本排序得分 乘以权重2

query.set("defType","dismax");

query.setQuery("淘宝女装");

query.add("qf","user_nick^2")

//文本得分排序 乘以函数值

query.set("defType","dismax");

query.setQuery("淘宝女装");

query.add("bf","div(fans_count,1)");//相除

//文本得分排序 乘以函数值

query.set("defType","lucene");

query.setQuery("user_nick:淘宝女装 AND _val_:fans_count");

//文本得分排序 乘以函数值

query.set("defType","lucene");

query.setQuery("user_nick:淘宝女装 AND _val_:fans_count^2");

//文本得分排序 乘以函数值

query.set("defType","lucene");

query.setQuery("(user_nick:淘宝女装)^0.5 AND _val_:fans_count^2");

//文本得分排序 乘以函数值

query.set("defType","lucene");

query.setQuery("(user_nick:淘宝女装)^0.5 AND _val_:1.5");

//文本得分排序 与函数值 指定组合

query.set("defType","func");

query.add("qq","{!dismax qf=user_nick}淘宝女装");

query.add("q","product(fans_count, query($qq,0.1))") ;

个性化排序

//这里搜索user_nick:淘宝女装的时候,文本得分可以是调整过的或者默认的

query.setQuery("(user_nick:淘宝女装)^8 OR (user_descrip:淘宝女装)^2");

query.setQuery("((user_nick:淘宝女装) AND _val_:fans_count) OR (user_descrip:淘宝女装)^2");

其他,函数查询的发挥。文本域函数结合查询的发挥了。

参考链接

http://wiki.apache.org/solr/DisMaxQParserPlugin

http://wiki.apache.org/solr/ExtendedDisMax

http://wiki.apache.org/solr/FunctionQuery

时间: 2024-10-09 07:36:19

solr特点三: 排序样例汇总的相关文章

教你写Http框架(二)——三个样例带你深入理解AsyncTask

这个标题大家不要奇怪,扯Http框架怎么扯到AsyncTask去了,有两个原因:首先是Http框架除了核心http理论外.其技术实现核心也是线程池 + 模板 + handler,而AsyncTask又正好也是这三者的完美结合.其次,也是自己在面试中发现大量的安卓开发人员全然不了解AsyncTask的原理和技术细节.而AsyncTask的思想在我们设计app框架和性能调优的时候是非常实用的.所以这里特地写一篇关于AsyncTask的博文. 老规矩,我的习惯还是通过写demo,把核心技术一点点剥离出

Hadoop辅助排序样例一

1. 样例数据 011990-99999 SIHCCAJAVRI 012650-99999 TYNSET-HANSMOEN 012650-99999 194903241200 111 012650-99999 194903241800 78 011990-99999 195005150700 0 011990-99999 195005151200 22 011990-99999 195005151800 -11 2. 需求 3. 思路.代码 将气象站ID相同的气象站信息和天气信息交由同一个 Re

Hadoop辅助排序样例二

1. 需求 求每年的最高温度 2. 样例数据 1995 10 1996 11 1995 16 1995 22 1996 26 1995 3 1996 7 1996 10 1996 20 1996 33 1995 21 1996 9 1995 31 1995 -13 1995 22 1997 -2 1997 28 1997 15 1995 8 3. 思路.代码 将记录按年份分组并按温度降序排序,然后才将同一年份的所有记录送到一个 reducer 组,则各组的首条记录就是这一年的最高温度.实现此方案

solr特点三: QueryElevation(编辑结果排序)

在理想的情况下,搜索引擎只返回与用户查询相关的文档.而在现实的查询中,编辑(没发现更合适的表达)通常需要指定特定文档在搜索结果中的特定位置.这样做有很多原因.或许 “置顶” 的文档就是最好的查询结果.也可能是公司想让客户从相似的选择中找到利润率较高的产品.还可能是由第三方付费,提高某些查询词语的排名.不管是什么原因,对于一般的查询,要根据相关度来排名,让特定的文档出现在特定的位置,通常是很困难的(甚至是不可能的).而且,即便搜索引擎能为某个查询达到这个目的,它也很可能会在这个过程中破坏其他 50

Python word_cloud 样例 标签云系列(三)

转载地址:https://zhuanlan.zhihu.com/p/20436642word_cloud/examples at master · amueller/word_cloud · GitHub 上面是官方样例.这一篇里的大部分尝试都基于这些样例进行修改.前提是你已经完成了安装,依照上一篇修改了 FONT_PATH . 还记得 http://zhuanlan.zhihu.com/666666/20432734 里提到的中文分词方法吧,这次我们就不再赘述对文本的预处理了.有所不同的是,在

TreeSet排序,存储自己定义对象,自己定义比較器演示样例

Set:无序.不能够反复元素. |--HashSet:数据结构是哈希表.线程是非同步的. 保证元素唯一性的原理:推断元素的hashCode值是否同样. 假设同样,还会继续推断元素的equals方法.是否为true. |--TreeSet:能够对Set集合中的元素进行排序. 底层数据结构是二叉树. 保证元素唯一性的根据:compareTo方法return 0. TreeSet排序的第一种方式:让元素自身具备比較性. 元素须要实现Comparable接口,覆盖compareTo方法. 也种方式也成为

c语言学习之结构篇代码演示样例-输入n个同学的姓名,数学英语成绩,依照平均分从低到高排序并输出

#include<stdio.h> void main(){ const int count = 5;//定义数量 struct student{ char name[80]; float math,eng; float aver; }stu[count],temp; //输入 for (int i = 0; i < count; i++){ scanf("%s%f%f", stu[i].name, &stu[i].math, &stu[i].eng)

5、Cocos2dx 3.0游戏开发找小三之测试样例简介及小结

重开发者的劳动成果,转载的时候请务必注明出处:http://blog.csdn.net/haomengzhu/article/details/27186557 测试样例简介 Cocos2d-x 为我们提供了十分丰富的测试样例,这些测试样例是在引擎开发过程中为测试引擎的正确性而编写的代码,同时也是演示引擎各个部分如何使用的良好示例. 打开Cocos2d-x根目录下build文件夹下的cocos2d-win32.vc2012.sln解决方案,设置其中的 cpp-tests 项目为启动项目,成功运行后

.Net Native 系列《三》:.NET Native部署测试方案及样例

之前一文<c++的性能, c#的产能?!鱼和熊掌可以兼得,.NET NATIVE初窥> 获得很多朋友支持和鼓励,也更让我坚定做这项技术的推广者,希望能让更多的朋友了解这项技术,于是先从官方信息的翻译开始做起. 此系列系小九的学堂原创翻译,翻译自微软官方开发向导,一共分为六个主题.本文是第三个主题:.NET Native部署测试及样例. 向导文链接:<C++的性能C#的产能?! - .Net Native 系列:开发向导> [小九的学堂,致力于以平凡的语言描述不平凡的技术.如要转载,