1 Solr管理页面的查询入口

选中需要查询的SolrCore, 然后在菜单栏选择[Query]:

2 Solr查询输入框简介

(1) select: 查询请求处理器.

(2) q: 是query的简写, 指定查询表达式.

*:* ——表示查询所有, 比如:
product_name:花儿朵朵, 表示"product_name"字段中包含"花儿朵朵".

(3) fq: 是filter query的简写, 是一个数组, 可以指定多个. 在q的查询结果中, 执行过滤. 前提是: 必须先指定q查询.

product_price:[* TO 20], 表示查询商品价格在20块钱以内, 包含20;
product_price:[* TO 20}, 表示查询商品价格在20块钱以内, 不包含20.

(4) sort: 指定搜索结果的排序.

product_price desc —— 表示按照商品价格降序;
product_price asc —— 表示按照商品价格升序;
product_price desc, product_catalog asc —— 表示按商品价格降序, 按商品分类id升序(多个Field排序, 以半角逗号<也就是英文中的逗号“,”>分割).

(5) start,rows: 指定搜索结果分页:

与MySQL等数据库中的limit不同, 这里:

start —— 表示从第start条文档开始;
rows —— 表示返回rows条文档.

(6) fl: 是field list的简写, 用来指定搜索结果显示的域列表.

(7) id, product_name, product_price, product_catalog_name, 表示返回的结果中, 只显示商品Id, 商品名称, 商品价格, 商品类别名称这几个Field的内容, 其他的Field不显示.

(8) df: 是default field的简写, 指定默认搜索域 —— 只能指定一个, 会覆盖schema.xml文件中的配置.

(9) wt: 是writer type的简写, 指定返回搜索结果时的显示格式, 也就是响应的数据的格式, 其中csv是一种类似于记事本的格式.

indent: 缩进, 格式良好地显示查询结果;
debugQuery: 打印查询的调试信息.

(10) dismax、edismax: 查询解析器, 一般不选择. /select等使用的是标准查询解析器.

(11) hl: 是highlight的简写, 用来设置高亮显示. 前提: 高亮显示的field, 需要存储, 也就是在schema.xml文件中配置stored=true.

hl.fl: 高亮显示的域的名称;
hl.simple.pre: 高亮显示的HTML标签前缀;
hl.simple.post: 高亮显示的HTML标签后缀;
hl.requireFieldMatch: 默认为false, 若选中(为true), 则需要hl.fl指定字段, 查询结果才会高亮;
hl.usePhraseHighlighter: 如果查询语句中含有引号括起来的短语, 那么只有完全匹配短语的内容才会高亮;
hl.highlightMultiTerm: 默认为false, 若选中且hl.usePhraseHighlighter为true时, 如果使用通配符和模糊搜索, 那么会确保与通配符匹配的term才会高亮.

(12) facet: 是Solr中的统计接口, 意为分组统计(分片统计), 如电商中的组合多条件搜索:

facet查询设置界面:

facet.query: 指定组内初始化统计条件
facet.field: 指定分组统计的域的名称(通常使用分类域)
facet.prefix: 指定组内过滤查询条件的前缀

(13) spatial: 空间查询, 是基于经纬度坐标点的地理位置查询.

(14) spellcheck: 拼写检查, 也就是在输入检索的字段时, 尽心智能提醒和匹配.

3 Solr管理页面的查询方案

说明: 使用SolrJ实现页面的查询效果, 要求参数和结果与页面一致.

(1) 页面搜索条件:

(2) 页面搜索结果:
文档结果以及分组统计结果:

(3) 高亮显示结果:

注意事项:

① 由上图可知, Solr在高亮查询时, 高亮结果集与正常结果集是分开返回的, 为了与正常结果集中的其他内容相匹配, 这里需要设置主键进行结果的关联.
② 另外, 对于multiValued=true的字段, 不要进行高亮设置 -- 它只会返回匹配高亮的值, 不能确定是何条数据.
③ 也可通过HTTP请求的方式进行高亮设置, HTTP请求示例:
http://localhost:7070/solr/select?q=product_name:花儿朵朵&hl=true&hl.fl=product_name&hl.simple.pre=<font color='red'>&hl.simple.post=</font>
④ 也可通过配置solrconfig.xml文件, 是默认搜索方案具有高亮功能: 在<requestHandler name="/select" class="solr.SearchHandler" default="true">下配置.

版权声明

作者: 马瘦风

出处: 博客园 马瘦风的博客

您的支持是对博主的极大鼓励, 感谢您的阅读.

本文版权归博主所有, 欢迎转载, 但请保留此段声明, 并在文章页面明显位置给出原文链接, 否则博主保留追究相关人员法律责任的权利.

Solr 08 - 在Solr Web管理页面中查询索引数据 (Solr中各类查询参数的使用方法)的更多相关文章

  1. ASP.NET MVC搭建项目后台UI框架—8、将View中选择的数据行中的部分数据传入到Controller中

    目录 ASP.NET MVC搭建项目后台UI框架—1.后台主框架 ASP.NET MVC搭建项目后台UI框架—2.菜单特效 ASP.NET MVC搭建项目后台UI框架—3.面板折叠和展开 ASP.NE ...

  2. View中选择的数据行中的部分数据传入到Controller中

    将View中选择的数据行中的部分数据传入到Controller中   ASP.NET MVC搭建项目后台UI框架—1.后台主框架 ASP.NET MVC搭建项目后台UI框架—2.菜单特效 ASP.NE ...

  3. 一个I/O线程可以并发处理N个客户端连接和读写操作 I/O复用模型 基于Buf操作NIO可以读取任意位置的数据 Channel中读取数据到Buffer中或将数据 Buffer 中写入到 Channel 事件驱动消息通知观察者模式

    Tomcat那些事儿 https://mp.weixin.qq.com/s?__biz=MzI3MTEwODc5Ng==&mid=2650860016&idx=2&sn=549 ...

  4. SQL批量更新数据库中所有用户数据表中字段类型为tinyint为int

    --SQL批量更新数据库中所有用户数据表中字段类型为tinyint为int --关键说明:--1.从系统表syscolumns中的查询所有xtype='48'的记录得到类型为[tinyint]的字段- ...

  5. 批量替换数据库中所有用户数据表中字段数据类型为char和varchar到nvarchar的脚本

    解决问题:字段类型为char的总是占用指定字节长度(末尾好多空白符号),varchar数据类型长度一个汉字占2个字节,内容存储为中文的字段个人建议全部使用nvarchar. 操作说明:打开SQL Se ...

  6. 【MySQL】MySQL中查询出数据表中存在重复的值list

    1.目的:查询MySQL数据表中,重复记录的值 2.示例: 3.代码: select serial_num,count(*) as count FROM card_ticket GROUP BY se ...

  7. 转:Sql Server中清空所有数据表中的记录

    如果要删除数据表中所有数据只要遍历一下数据库再删除就可以了,清除所有数据我们可以使用搜索出所有表名,构造为一条SQL语句进行清除了,这里我一一给各位同学介绍.   使用sql删除数据库中所有表是不难的 ...

  8. Sql Server中清空所有数据表中的记录

    Sql Server中清空所有数据表中的记录 清空所有数据表中的记录: 代码如下:exec sp_msforeachtable  @Command1 ='truncate table ?'删除所有数据 ...

  9. C语言:将ss所指字符串中所有下标为奇数位上的字母转换成大写,若不是字母,则不转换。-删除指针p所指字符串中的所有空白字符(包括制表符,回车符,换行符)-在带头结点的单向链表中,查找数据域中值为ch的结点,找到后通过函数值返回该结点在链表中所处的顺序号,

    //将ss所指字符串中所有下标为奇数位上的字母转换成大写,若不是字母,则不转换. #include <stdio.h> #include <string.h> void fun ...

随机推荐

  1. 四、自动化平台搭建-Django-如何做验证码

    前提:安装包   pip install pillow==3.4.1 1.打开booktest/views.py,创建视图verify_code. from PIL import Image, Ima ...

  2. MongoDb安装和快速入门

    1.Mongodb安装 2.mongodb的增删改查 3.MongoDB数据类型 4.Mongodb $关键字 $修改器 5.MongoDB 之 "$" 的奇妙用法 6.Mongo ...

  3. <算法图解>读书笔记:第3章 递归

    第3章 递归 3.1 递归 程序调用自身的编程技巧称为递归( recursion).递归做为一种算法在程序设计语言中广泛应用. 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一 ...

  4. 1064 Financial Management

    http://acm.hdu.edu.cn/showproblem.php?pid=1064 思路:看懂英文就很简单,就是12个数相加求平均数就ok了. 扩展: C++ 标准输入输出流的控制符 #in ...

  5. [CF364D]Ghd

    [CF364D]Ghd 题目大意: 有\(n(n\le10^6)\)个数\(A_{1\sim n}(A_i\le10^{12})\),从中选取\(\lceil\frac n2\rceil\)个数,使得 ...

  6. C#三目运算符

    在编写项目的时候,会经常用到 if else 判断语句,但有些简单的判断或赋值,可以通过三目运算符来完成! 例如: int sex=0; string sexText=""; if ...

  7. error C2371: 'IServiceProvider' : redefinition; different basic types

    需要将#include <windows.h>放到using namespace System;前面. #include <windows.h>using namespace ...

  8. SpringBoot报错:Invalid bound statement (not found)

    错误原因: 没有发现Mybatis配置文件的路径 解决方法: 检查Mapper包名与xml文件标签的namespace数据名称是否相同 <mapper namespace="com.t ...

  9. Java_异常处理

    这篇我们聊聊java中的异常.首先我们要知道什么是异常? Exception: exception翻译过来就是“意外”的意思.事实上,异常的本质就是程序的错误,包括程序逻辑错误和系统错误.错误在编写程 ...

  10. hbase数据原理及基本架构

    第一:hbase介绍 hbase是一个构建在hdfs上的分布式列存储系统: hbase是apache hadoop生态系统中的重要一员,主要用于海量结构化数据存储 从逻辑上讲,hbase将数据按照表. ...