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 ...
随机推荐
- CyclicBarrier开启多个线程进行计算,最后统计计算结果
有一个大小为50000的数组,要求开启5个线程分别计算10000个元素的和,然后累加得到总和 /** * 开启5个线程进行计算,最后所有的线程都计算完了再统计计算结果 */ public class ...
- Deep Learning专栏--强化学习之从 Policy Gradient 到 A3C(3)
在之前的强化学习文章里,我们讲到了经典的MDP模型来描述强化学习,其解法包括value iteration和policy iteration,这类经典解法基于已知的转移概率矩阵P,而在实际应用中,我们 ...
- [Silverlight 4] Textbox style模擬Textblock 使可以選取、複製
childwindow 做為訊息視窗,使用textblock,可是textbloc無法選取內容及複製, 就改用textbox假裝成textblock ---原本的textblock <contr ...
- Python学习笔记之将数据写入到文件中
10-3 访客:编写一个程序,提示用户输入其名字:用户作出响应后,将其名字写入到文件guest.txt 中. 编写Python代码: username = input("Please ent ...
- BindRequired and Required
[https://www.cnblogs.com/tdfblog/p/required-and-bindrequired-in-asp-net-core-mvc.html] Required:对值进行 ...
- 数据库系列(五)之 mysql的伸缩性
这篇文章,主要讲述mysql的伸缩性.在国内mysql一直都是使用得最多的数据库,在国外也排名前三.mysql是一款开源的.性能较高的数据库. 伸缩性是指在软件设计中,软件(数据库.应用程序)通过特定 ...
- javascript 函数表达和闭包
函数表达式和闭包 针对JS高级程序设计这本书,主要是理解概念,大部分要点源自书内.写这个主要是当个笔记加总结 存在的问题请大家多多指正! 定义函数的两种方法 函数声明: function functi ...
- Gin-Go学习笔记三:Gin-Web框架 JS分页
JS 分页 1> JS分页,业务逻辑 (1) 分页采用的是一个叫jquery.pagination.js的一个jquery插件 (2) 需要jquery的支持,此项目中使 ...
- Flutter 徐徐图之(一)—— 从搭建开发环境到 Hello World
一.环境变量 由于众所周知的原因,在国内访问 Flutter 有时可能会受到限制,所以在开发之前,需要先配置环境变量 MacOS: 编辑 ~/.bash_profile 文件 vim ~/.bash_ ...
- MySql数据库 timeout超时报警的解决方法
今天做查询mysql数据库是,因为数据量大所以报错 最后在 连接的地方做了如下改动: MySqlCommand cmd = new MySqlCommand(procedureName, conn); ...