查询web界面如下:

基本查询配置
-
q 查询的关键字,此参数最为重要,例如,q=id:1,默认为
q=*:*
,相当于sql中的where 1 = 1
。当有多个字段要同时查询:q= content:API AND name=爱谁谁
**q** 查询的关键字
-
fl 指定返回哪些字段,用逗号或空格分隔,注意:字段区分大小写,例如,fl= id,title,sort
**fl** 指定返回哪些字段
-
start 返回结果的第几条记录开始,一般分页用,默认0开始
-
rows 指定返回结果最多有多少条记录,默认值为 10,配合start实现分页
-
sort 排序方式,例如id desc 表示按照 “id” 降序,多个排序用逗号分隔
分页排序
-
wt (writer type)指定输出格式,有 xml, json, php等
-
fq (filter query)过虑查询,提供一个可选的筛选器查询。返回在q查询符合结果中同时符合的fq条件的查询结果,例如:q=id:1&fq=sort:[1 TO 5],找关键字id为1 的,并且sort是1到5之间的。
查询过滤
-
df 默认的查询字段,一般默认指定。
-
qt (query type)指定那个类型来处理查询请求,一般不用指定,默认是standard。
-
indent 返回的结果是否缩进,默认关闭,用 indent=true|on 开启,一般调试json,php,phps,ruby输出才有必要用这个参数。
-
version 查询语法的版本,建议不使用它,由服务器指定默认值。
Solr的检索运算符
-
:
指定字段查指定值,如返回所有值:
指定字段查指定值
-
?
表示单个任意字符的通配
单个任意字符的通配
-
*
表示多个任意字符的通配(不能在检索的项开始使用*或者?符号) -
~
表示模糊检索,如检索拼写类似于”roam”的项这样写:roam将找到形如foam和roams的单词;roam0.8,检索返回相似度在0.8以上的记录。
模糊查询
-
AND、||
布尔操作符 -
OR、&&
布尔操作符 -
NOT、!、-
(排除操作符不能单独与项使用构成查询) -
+
存在操作符,要求符号”+”后的项必须在文档相应的域中存在² -
( )
用于构成子查询 -
[]
包含范围检索,如检索某时间段记录,包含头尾,date:[201507 TO 201510] -
{}
不包含范围检索,如检索某时间段记录,不包含头尾date:{201507 TO 201510}
高亮
-
h1 是否高亮,hl=true,表示采用高亮
-
hl.fl 设定高亮显示的字段,用空格或逗号隔开的字段列表。要启用某个字段的highlight功能,就得保证该字段在schema中是stored。如果该参数未被给出,那么就会高亮默认字段 standard handler会用df参数,dismax字段用qf参数。你可以使用星号去方便的高亮所有字段。如果你使用了通配符,那么要考虑启用hl.requiredFieldMatch选项。
-
hl.requireFieldMatch 如果置为true,除非用hl.fl指定了该字段,查询结果才会被高亮。它的默认值是false。
-
hl.usePhraseHighlighter 如果一个查询中含有短语(引号框起来的)那么会保证一定要完全匹配短语的才会被高亮。
-
hl.highlightMultiTerm 如果使用通配符和模糊搜索,那么会确保与通配符匹配的term会高亮。默认为false,同时hl.usePhraseHighlighter要为true。
-
hl.fragsize 返回的最大字符数。默认是100.如果为0,那么该字段不会被fragmented且整个字段的值会被返回。
高亮
通过solrj 的方式获取高亮
public static void queryHighlighter(String kw){
SolrQuery solrQuery = new SolrQuery();
solrQuery.setQuery("content:"+kw); //设置查询关键字
solrQuery.setHighlight(true); //开启高亮
solrQuery.addHighlightField("content"); //高亮字段
solrQuery.setHighlightSimplePre("<font color='red'>"); //高亮单词的前缀
solrQuery.setHighlightSimplePost("</font>"); //高亮单词的后缀
solrQuery.setHighlightFragsize(1);
/**
hl.snippets
hl.snippets参数是返回高亮摘要的段数,因为我们的文本一般都比较长,含有搜索关键字的地方有多处,如果hl.snippets的值大于1的话,
会返回多个摘要信息,即文本中含有关键字的几段话,默认值为1,返回含关键字最多的一段描述。solr会对多个段进行排序。
hl.fragsize
hl.fragsize参数是摘要信息的长度。默认值是100,这个长度是出现关键字的位置向前移6个字符,再往后100个字符,取这一段文本。*/
solrQuery.setHighlightFragsize(15);
try {
QueryResponse query = solrServer.query(solrQuery);
SolrDocumentList results = query.getResults();
NamedList<Object> response = query.getResponse();
NamedList highlighting = (NamedList) response.get("highlighting");
for (int i = 0; i <highlighting.size() ; i++) {
System.out.println(highlighting.getName(i)+":"+highlighting.getVal(i));
}
for (SolrDocument result : results) {
System.out.println(result.toString());
}
} catch (SolrServerException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}

网友评论