Solr的核心操作案例
@Service
public class SearchServiceImpl implements SearchService {
@Autowired
private SolrTemplate solrTemplate;
@Autowired
private TbItemMapper itemMapper;
@Override
public Map search(Map searchMap) {
String keywords = (String) searchMap.get("keywords");
System.out.println("查询关键字是:"+keywords);
//通过solrTemplate进行索引库的查询
//直接创建高亮查询
SimpleHighlightQuery query = new SimpleHighlightQuery(); //不需要指定*:*
//封装搜索条件
Criteria criteria = new Criteria("item_keywords"); //要查询的域
criteria = criteria.contains(keywords); //要查询的条件
query.addCriteria(criteria);
//设置高亮效果选项
HighlightOptions options = new HighlightOptions();
options.addField("item_title"); //设置哪个域加高亮效果
options.setSimplePrefix("<em style='color:red'>"); // 高亮头部
options.setSimplePostfix("</em>"); // 高亮尾部
query.setHighlightOptions(options);
//增加过滤查询条件--商品分类
String categoryStr = (String) searchMap.get("category");
if(categoryStr!=null && categoryStr.length() > 0){
FilterQuery filterQuery = new SimpleFilterQuery();
Criteria filterCriteria = new Criteria("item_category"); //设置Criteria
filterCriteria = filterCriteria.contains(categoryStr); //进行查询比较
filterQuery.addCriteria(filterCriteria);
//增加过滤查询条件
query.addFilterQuery(filterQuery);
}
//增加过滤查询条件--商品品牌
String brandStr = (String) searchMap.get("brand");
if(brandStr!= null && brandStr.length() > 0){
SimpleFilterQuery filterQuery = new SimpleFilterQuery();
Criteria fileterCriteria = new Criteria("item_brand");
fileterCriteria = fileterCriteria.contains(brandStr); //进行品牌搜索条件封装
filterQuery.addCriteria(fileterCriteria);
query.addFilterQuery(filterQuery);
}
//增加过滤查询条件--规格
Map<String,String> specMap = (Map) searchMap.get("spec");
if(specMap!=null){
for (String key : specMap.keySet()) {
SimpleFilterQuery filterQuery = new SimpleFilterQuery();
Criteria filterCriteria = new Criteria("item_spec_"+key);
filterCriteria = filterCriteria.contains(specMap.get(key)); //设置搜索的规格内容
filterQuery.addCriteria(filterCriteria);
query.addFilterQuery(filterQuery);
}
}
//增加过滤查询条件--价格
String priceStr = (String) searchMap.get("price");
if(priceStr != null && priceStr.length() > 0){
String[] prices = priceStr.split("-");
//获取起始值作为价格初始条件
SimpleFilterQuery filterQuery1 = new SimpleFilterQuery();
Criteria filterCriteria1 = new Criteria("item_price");
filterCriteria1 = filterCriteria1.greaterThanEqual(prices[0]); //price>= 价格条件查询
filterQuery1.addCriteria(filterCriteria1);
query.addFilterQuery(filterQuery1);
if(!"*".equals(prices[1])){ //当结束价格不定*才会有结束价格范围,否则3000-*,就是起始是3000,没有结束价格
//获取结束值作为价格结束条件
SimpleFilterQuery filterQuery2 = new SimpleFilterQuery();
Criteria filterCriteria2 = new Criteria("item_price");
filterCriteria2 = filterCriteria2.lessThanEqual(prices[1]); //price<= 价格条件查询
filterQuery2.addCriteria(filterCriteria2);
query.addFilterQuery(filterQuery2);
}
}
//设置价格升降序查询
String sortStr = (String) searchMap.get("sort");
Sort sort;
if("ASC".equals(sortStr)){
//设置价格升序查询
sort = new Sort(Sort.Direction.ASC, "item_price"); //参数一是设置升降序 参数二设置升降序的域
}else{
//设置价格降序查询
sort = new Sort(Sort.Direction.DESC, "item_price");
}
query.addSort(sort);
Integer pageNo = (Integer) searchMap.get("pageNo");
Integer pageSize = (Integer) searchMap.get("pageSize");
//设置分页相关参数
query.setRows(pageSize); //pageSize
query.setOffset((pageNo-1)*pageSize);//offset = (pageNo - 1)*pageSize,起始的索引数
//直接采用solr的高亮查询
HighlightPage<TbItem> page = solrTemplate.queryForHighlightPage(query, TbItem.class);
List<TbItem> content = page.getContent();
for (TbItem item : content) {
List<HighlightEntry.Highlight> highlights = page.getHighlights(item);
if(highlights.size() > 0){ //防止出现的结果item_title中没有高亮关键字
List<String> snipplets = highlights.get(0).getSnipplets();
if(snipplets.size() > 0){
item.setTitle(snipplets.get(0)); //设置高亮后的效果
}
}
}
//封装前端分页插件的需要的属性,rows,total(模仿PageResult)
Map returnMap = new HashMap<>();
returnMap.put("rows", content);
returnMap.put("total",page.getTotalElements()); //TotalElements总记录数
//page.getTotalPages()总页数
return returnMap;
}
@Override
public void importData(Long[] ids) {
//根据导入的goods的id,查询出本次需要导入的item对象,保存到solr索引库
TbItemExample example = new TbItemExample();
example.createCriteria().andGoodsIdIn(Arrays.asList(ids));
List<TbItem> items = itemMapper.selectByExample(example);
for (TbItem item : items) {
System.out.println("导入了:"+item.getTitle());
}
solrTemplate.saveBeans(items);
solrTemplate.commit(); //提交一下
}
@Override
public void removeData(Long[] ids) {
TbItemExample example = new TbItemExample();
example.createCriteria().andGoodsIdIn(Arrays.asList(ids));
List<TbItem> items = itemMapper.selectByExample(example);
for (TbItem item : items) {
solrTemplate.deleteById(item.getId() + "");
System.out.println("删除了:"+item.getTitle());
}
solrTemplate.commit();
}
}
Solr的核心操作案例的更多相关文章
- Shiro 核心功能案例讲解 基于SpringBoot 有源码
Shiro 核心功能案例讲解 基于SpringBoot 有源码 从实战中学习Shiro的用法.本章使用SpringBoot快速搭建项目.整合SiteMesh框架布局页面.整合Shiro框架实现用身份认 ...
- 关于activiti流程通过、驳回、会签、转办、中止、挂起等核心操作功能的封装
http://blog.csdn.net/aochuanguying/article/details/7594197 package com.famousPro.process.service.imp ...
- Solr多核心及分词器(IK)配置
Solr多核心及分词器(IK)配置 多核心的概念 多核心说白了就是多索引库.也可以理解为多个"数据库表" 说一下使用multicore的真实场景,比若说,产品搜索和会员信息搜索 ...
- Solr 14 - SolrJ操作SolrCloud集群 (Solr的Java API)
目录 1 pom.xml文件的配置 2 SolrJ操作SolrCloud 1 pom.xml文件的配置 项目的pom.xml依赖信息请参照: Solr 09 - SolrJ操作Solr单机服务 (So ...
- Activiti之流程通过、驳回、会签、转办、中止、挂起等核心操作封装(Activiti5.9)
http://blog.csdn.net/rosten/article/details/38300267 package com.famousPro.process.service.impl; imp ...
- AngularJS基于MVC的复杂操作案例
AngularJS基于MVC的复杂操作案例 <!DOCTYPE html> <html> <head> <meta charset="UTF-8&q ...
- [OpenCV-Python] OpenCV 核心操作 部分 III
部分 III核心操作 OpenCV-Python 中文教程(搬运)目录 9 图像的基础操作 目标 • 获取像素值并修改 • 获取图像的属性(信息) • 图像的 ROI() • 图像通道的拆分及合并几乎 ...
- linux磁盘 分区 物理卷 卷组 逻辑卷 文件系统加载点操作案例
转自:truemylife.linux磁盘 分区 物理卷 卷组 逻辑卷 文件系统加载点操作案例 基本概念: 磁盘.分区.物理卷[物理部分] 卷组[中间部分] 逻辑卷.文件系统[虚拟化后可控制部分] 磁 ...
- solr的客户端操作:使用solrj进行curd操作
导入相关的jar包 <dependency> <groupId>org.apache.solr</groupId> <artifactId>solr-s ...
随机推荐
- k8s网络原理
https://blog.csdn.net/watermelonbig/article/details/80646988 k8s中,每个 Pod 都有一个独立的 IP 地址,所有 Pod 在一个网络空 ...
- Mysql序列(七)—— order by优化
前言 在mysql中满足order by的处理方式有两种: 让索引满足排序,即扫描有序索引然后再找到对应的行结果,这样结果即是有序: 使用索引查询出结果或者扫描表得到结果然后使用filesort排序: ...
- Jquery ajax与asp.net MVC前后端各种交互
1.Jquery通过ajaxSubmit提交表单 if (jQuery("#Edit_from").validate().form()) { jQuery("#Edit_ ...
- ASP.NET Core使用MongoDB数据库
环境:Asp.Net Core Mvc 2.2,MongoDB 4.09 参考文档:http://mongodb.github.io/mongo-csharp-driver/ http://mongo ...
- Service Mesh服务网格新生代--Istio
原文: 数人云|万字解读:Service Mesh服务网格新生代--Istio 参考: istio 简介 Istio是啥?一文带你彻底了解! 使用Istio治理微服务入门 Istio 流量管理 ist ...
- Java集合大全
上图为整理的集合类图关系,带对号标志的为线程安全类. 区别说明: 1.List Set Map Queue的区别List: 有序,可以多个元素引用相同的对象Set: 无序,不重复,不可以多个元素引用相 ...
- Cron Expressions——Cron 表达式(QuartZ调度时间配置)
如果你需要像日历那样按日程来触发任务,而不是像SimpleTrigger 那样每隔特定的间隔时间触发,CronTriggers通常比SimpleTrigger更有用. 使用CronTrigger,你可 ...
- XGBoost使用教程(进阶篇)三
一.Importing all the libraries import pandas as pdimport numpy as npfrom matplotlib import pyplot as ...
- tf.variable_scope()和tf.name_scope()
1.tf.variable_scope 功能:tf.variable_scope可以让不同命名空间中的变量取相同的名字,无论tf.get_variable或者tf.Variable生成的变量 Tens ...
- 第08节-开源蓝牙协议栈BTStack数据处理
本篇博客根据韦东山的视频整理所得. 在上篇博客,通过阅读BTStack的源码,大体了解了其框架,对于任何一个BTStack的应用程序都有一个main函数,这个main函数是统一的.这个main函数做了 ...