solr java代码
添加依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-solr</artifactId>
</dependency>
1、controller
@PostMapping("/solrSearchDemand")
@ResponseBody
public JsonResponse solrSearchDemand(@RequestBody SolrDemandSerachPageListRequest request) {
PageListResponse<DemandSolrModel> responseBody = new PageListResponse<>();
Pageable pageable = null;
if (StringUtils.isNotBlank(request.getSort()) && StringUtils.isNotBlank(request.getDirection())) {
Sort.Order demandSort = new Order(Sort.Direction.valueOf(request.getDirection()), request.getSort());
Sort sort = new Sort(demandSort);
pageable = request.getPageable(sort);
} else {
pageable = request.getPageable("createTime", Sort.Direction.DESC);
}
final Page<DemandSolrModel> page = demandSolrService.filterTitleUsernameContent(request.getTerm(), request.getTagId(), request.getAppId(),request.getHasHot(), pageable);
if (!page.hasContent()) {
responseBody.setRecords(Collections.emptyList());
}
responseBody.setRecords(page.getContent());
responseBody.setPage(request.getPage());
responseBody.setPageSize(request.getPageSize());
responseBody.setTotalRecords(page.getTotalElements());
return JsonResponse.success(responseBody);
}
2、SolrDemandSerachPageListRequest 类如下
public class SolrDemandSerachPageListRequest extends PageListRequest {
/**
* 标签名查找
*/
private Integer tagId;
private Integer appId;
private Boolean hasHot;
public Boolean getHasHot() {
return hasHot;
}
public void setHasHot(Boolean hasHot) {
this.hasHot = hasHot;
}
public Integer getTagId() {
return tagId;
}
public void setTagId(Integer tagId) {
this.tagId = tagId;
}
public Integer getAppId() {
return appId;
}
public void setAppId(Integer appId) {
this.appId = appId;
}
}
PageListRequest类如下:
import org.apache.commons.lang3.StringUtils;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort; public class PageListRequest { /**
* 搜索的关键字
*/
private String term; /**
* 排序的字段
*/
private String sort; /**
* 排序的方向
*/
private String direction; /**
* 页码从1开始
*/
private int page; /**
* 条数
*/
private int pageSize; public String getSort() {
return sort;
} public void setSort(String sort) {
this.sort = sort;
} public String getDirection() {
return direction;
} public void setDirection(String direction) {
this.direction = direction;
} public int getPage() {
return page;
} public void setPage(int page) {
this.page = page;
} public int getPageSize() {
return pageSize;
} public void setPageSize(int pageSize) {
this.pageSize = pageSize;
} public String getTerm() {
return term;
} public void setTerm(String term) {
this.term = term;
} public Sort.Direction getDirection(Sort.Direction defaultDirection) {
if (StringUtils.isBlank(direction)) {
return defaultDirection;
}
return Sort.Direction.valueOf(direction);
} public Sort getSort(String defaultSortField, Sort.Direction defaultDirection) {
if (StringUtils.isNotBlank(sort)) {
Sort sort = new Sort(getDirection(defaultDirection), this.sort);
return sort;
} else {
Sort sort = new Sort(getDirection(defaultDirection), defaultSortField);
return sort;
}
} public Pageable getPageable(String defaultSortField, Sort.Direction defaultDirection) {
// Pageable 页码是从0开始的,所以要减1操作
PageRequest pageRequest = new PageRequest(this.page - 1, this.pageSize, getSort(defaultSortField, defaultDirection));
return pageRequest;
} public Pageable getPageable(Sort defaultSort) {
// Pageable 页码是从0开始的,所以要减1操作
PageRequest pageRequest = new PageRequest(this.page - 1, this.pageSize, defaultSort);
return pageRequest;
}
}
3、DemandSolrModel如下:
import java.io.Serializable;
import java.util.Date;
import java.util.List;
import org.apache.solr.client.solrj.beans.Field;
import org.springframework.data.annotation.Id;
import org.springframework.data.solr.core.mapping.SolrDocument;
/*
solrCoreName = "demand"
对应服务器的名字,这里的一定要看我上一篇文章的solr文章里面的managed-schema配置文件里的第(1)点*/
@SolrDocument(solrCoreName = "demand")
public class DemandSolrModel implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@Field
private int id;
@Field
private int userId;
@Field
private int appId;
@Field
private String content;
@Field
private Boolean hasHot;
@Field
private Date createTime;
@Field
private String title;
@Field
private String hyperlink;
@Field
private String fileUrl;
@Field
private String avatarImg;
@Field
private String username;
@Field
private List<String> tagName;
@Field
private List<Integer> tagId; get set 省
3、PageListResponse如下
import java.util.List;
public class PageListResponse<E> {
/**
* 列表数据
*/
private List<E> records;
/**
* 总的数量
*/
private long totalRecords;
private int page;
private int pageSize;
public List<E> getRecords() {
return records;
}
public void setRecords(List<E> records) {
this.records = records;
}
public long getTotalRecords() {
return totalRecords;
}
public void setTotalRecords(long totalRecords) {
this.totalRecords = totalRecords;
}
/*
* (non-Javadoc)
* @see org.springframework.data.domain.Page#getTotalPages()
*/
public int getTotalPages() {
return pageSize == 0 ? 1 : (int) Math.ceil((double) totalRecords / (double) pageSize);
}
public int getPage() {
return page;
}
public void setPage(int page) {
this.page = page;
}
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
}
4、service如下:
import com.messcat.imgrnt.solr.model.DemandSolrModel;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable; public interface DemandSolrService { Page<DemandSolrModel> filterTitleUsernameContent(String term, Integer tagId, Integer appId,Boolean hasHot, Pageable pageable); void indexDemand(int id);
}
5、service实现类如下:
import com.messcat.common.Constants;
import com.messcat.framework.common.util.CommonsUtils;
import com.messcat.imgrnt.custom.dao.DemandSolrCustomDao;
import com.messcat.imgrnt.service.DemandSolrService;
import com.messcat.imgrnt.solr.model.DemandSolrModel;
import com.messcat.imgrnt.solr.repo.DemandSolrRepository;
import javax.annotation.Resource;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.solr.core.SolrTemplate;
import org.springframework.data.solr.core.query.AnyCriteria;
import org.springframework.data.solr.core.query.Criteria;
import org.springframework.data.solr.core.query.SimpleQuery;
import org.springframework.stereotype.Component; @Component
public class DemandSolrServiceImpl implements DemandSolrService { @Resource
private SolrTemplate solrTemplate;
@Autowired
private DemandSolrCustomDao demandSolrCustomDao;
@Autowired
private DemandSolrRepository demandSolrRepository; @Override
public Page<DemandSolrModel> filterTitleUsernameContent(String term, Integer tagId, Integer appId,Boolean hasHot, Pageable pageable) {
SimpleQuery simpleQuery = new SimpleQuery();
/**
* 如果输入框的搜索条件不为空,则把条件加进去
*/
if (StringUtils.isNotBlank(term)) {
/*复制域*/
Criteria termCriteria = new Criteria(Constants.FIELD_TEXT).expression(CommonsUtils.quote(term));
simpleQuery.addCriteria(termCriteria);
}
if (tagId != null) {
Criteria contentCriteria = new Criteria("tagId").in(tagId);
simpleQuery.addCriteria(contentCriteria);
}
if (appId != null) {
Criteria contentCriteria = new Criteria("appId").is(appId);
simpleQuery.addCriteria(contentCriteria);
}
if (hasHot != null) {
Criteria contentCriteria = new Criteria("hasHot").is(hasHot);
simpleQuery.addCriteria(contentCriteria);
}
if (simpleQuery.getCriteria() == null) {
simpleQuery.addCriteria(AnyCriteria.any());
}
return solrTemplate.queryForPage(simpleQuery.setPageRequest(pageable), DemandSolrModel.class);
} @Override
public void indexDemand(int id) {
/*1:根据新增的demand 的id ,从demang,demand_rel,demand_tag_rel,demand_tag,user表获取数据*/
DemandSolrModel demandSolrModel = demandSolrCustomDao.selectDemandSolrByDemandId(id);
/*2:创建索引*/
if (demandSolrModel == null) {
return;
}
demandSolrRepository.save(demandSolrModel);
}
}
6、SolrTemplate 配置文件如下:
import com.messcat.common.solr.MyHttpSolrClient;
import org.apache.http.client.HttpClient;
import org.apache.solr.client.solrj.SolrClient;
import org.apache.solr.client.solrj.impl.BinaryResponseParser;
import org.apache.solr.client.solrj.impl.CloudSolrClient;
import org.springframework.boot.autoconfigure.solr.SolrProperties;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.solr.core.SolrTemplate;
import org.springframework.data.solr.repository.config.EnableSolrRepositories;
import org.springframework.util.StringUtils;
@SolrDocument(solrCoreName = "demand")
/*basePackages是指solr的实体类model所在的文件夹,因为要映射服务器 @SolrDocument=(solrCoreName="demand")*/
@Configuration
@EnableSolrRepositories(basePackages = {"com.messcat.imgrnt.solr"})
@EnableConfigurationProperties(SolrProperties.class)
public class SolrConfiguration { private final SolrProperties properties; public SolrConfiguration(SolrProperties properties) {
this.properties = properties;
} @Bean
public SolrClient solrClient(HttpClient httpClient) {
return createSolrClient(httpClient);
} private SolrClient createSolrClient(HttpClient httpClient) {
if (StringUtils.hasText(this.properties.getZkHost())) {
return new CloudSolrClient(this.properties.getZkHost());
}
return new MyHttpSolrClient(properties.getHost(), httpClient, new BinaryResponseParser());
} @Bean
public SolrTemplate solrTemplate(SolrClient server) throws Exception {
return new SolrTemplate(server);
}
}
注:有些包我没弄出来,所以有些代码是导包道不了,是可以用其它替代的,自己自行替换,要看自己的学习能力了
solr java代码的更多相关文章
- 分享知识-快乐自己:java代码 操作 solr
POM 文件: <!-- solr客户端 --> <dependency> <groupId>org.apache.solr</groupId> < ...
- 使用solrj查询数据(java代码)
实体类Student,添加Field注解 package com.cs.solr.entity; import org.apache.solr.client.solrj.beans.Field; pu ...
- solr 远程代码执行(CVE-2019-12409)
Apache Solr 远程代码执行漏洞(CVE-2019-12409) 简介 Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口.是apache的顶级开源项 ...
- 对一致性Hash算法,Java代码实现的深入研究
一致性Hash算法 关于一致性Hash算法,在我之前的博文中已经有多次提到了,MemCache超详细解读一文中"一致性Hash算法"部分,对于为什么要使用一致性Hash算法.一致性 ...
- 怎样编写高质量的java代码
代码质量概述 怎样辨别一个项目代码写得好还是坏?优秀的代码和腐化的代码区别在哪里?怎么让自己写的代码既漂亮又有生命力?接下来将对代码质量的问题进行一些粗略的介绍.也请有过代码质量相关经验的朋友 ...
- 数据结构笔记--二叉查找树概述以及java代码实现
一些概念: 二叉查找树的重要性质:对于树中的每一个节点X,它的左子树任一节点的值均小于X,右子树上任意节点的值均大于X. 二叉查找树是java的TreeSet和TreeMap类实现的基础. 由于树的递 ...
- java代码的初始化过程研究
刚刚在ITeye上看到一篇关于java代码初始化的文章,看到代码我试着推理了下结果,虽然是大学时代学的知识了,没想到还能做对.(看来自己大学时掌握的基础还算不错,(*^__^*) 嘻嘻……)但 ...
- JDBC——Java代码与数据库链接的桥梁
常用数据库的驱动程序及JDBC URL: Oracle数据库: 驱动程序包名:ojdbc14.jar 驱动类的名字:oracle.jdbc.driver.OracleDriver JDBC URL:j ...
- 利用Java代码在某些时刻创建Spring上下文
上一篇中,描述了如何使用Spring隐式的创建bean,但当我们需要引进第三方类库添加到我们的逻辑上时,@Conponent与@Autowired是无法添加到类上的,这时,自动装配便不适用了,我们需要 ...
随机推荐
- 用gcc/g++编译winsock程序
用gcc/g++编译winsock程序 D:\My\code>gcc -o getweb.exe getweb.c -lwin32socket 如果不加此句 -lwin32socket 编译会报 ...
- zuul集成Sentinel最新的网关流控组件
一.说明 Sentinel 网关流控支持针对不同的路由和自定义的 API 分组进行流控,支持针对请求属性(如 URL 参数,Client IP,Header 等)进行流控.Sentinel 1.6.3 ...
- MySQL高可用架构:mysql+keepalived实现
系统环境及架构 #主机名 系统版本 mysql版本 ip地址 mysqlMaster <a href="https://www.linuxprobe.com/" title= ...
- 【资源共享】eBook分享大集合
传送门:[GitHub] 欢迎各位指点,要是能补充更是感激不尽. 主要以IT领域经典书籍收藏,以备不时之需,不一定都能看完,权且当做收藏好玩. [x] 表示文件大小超过100M(LFS). 服务器系统 ...
- web 前端开发学习路线
初级 HTML 5 HTML 5 与 HTML 4 的区别 HTML 5 新增的主体结构元素 HTML 5 新增的非主体结构元素 HTML 5 表单新增元素与属性 HTML 5 表单新增元素与属性(续 ...
- JavaScript在web自动化测试中的作用
前言 JS的全称JavaScript,是一种运行在浏览器中的解释型脚本语言,通常用来实现web前端页面的基本功能,对于前端开发人员是不得不掌握的一门基本技能,但是对于做web自动化测试的人员来说,如果 ...
- HBase 系列(七)——HBase 过滤器详解
一.HBase过滤器简介 Hbase 提供了种类丰富的过滤器(filter)来提高数据处理的效率,用户可以通过内置或自定义的过滤器来对数据进行过滤,所有的过滤器都在服务端生效,即谓词下推(predic ...
- Spring中的属性编辑器的使用
Spring中的属性编辑器的使用 转载自 http://blog.sina.com.cn/s/blog_59ca2c2a0100jxwh.html Struts中用一个类型转换器,在Spring中也有 ...
- c++ 开发JNI
c++ 开发JNI C的预处理命令 #开头的就是c/c++的预处理命令 在编译之前 先会走预编译阶段 预编译阶段的作用就是 把 include进来的头文件 copy到源文件中 define这些宏定义 ...
- 【原创】(二)Linux物理内存初始化
背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: Kernel版本: ...