首先,必须吐槽一下,springboot这个elasticsearch包对于elasticsearch的支持十分不友好,目前只支持很低版本的elasticsearch,如果有哪位大牛知道如何兼容更高版本的elasticsearch,欢迎给我留言。

es下载地址:https://www.elastic.co/downloads/elasticsearch

我测试的es版本是2.4.5,spring-boot-starter-data-elasticsearch不支持太高版本的elasticsearch。

另外,我是在windows下安装的,在官网下载好zip包后,到bin文件夹下,运行elasticsearch.bat,测试:http://localhost:9200/,能正确显示版本就可以了。

安装好后,我们在pom.xml文件添加依赖

        <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-elasticsearch</artifactId>
<version>1.5.10.RELEASE</version>
</dependency>
在properties文件中添加es设置:
spring.data.elasticsearch.cluster-name=elasticsearch  es默认
spring.data.elasticsearch.cluster-nodes= 127.0.0.1:9300 es默认

实体类:

@Document(indexName = "monitoralarm", type = "monitorAlarms")//加上了@Document注解之后,默认情况下这个实体中所有的属性都会被建立索引、并且分词
public class MonitorAlarmVO implements Serializable { @Id
private Long id;
private String uniqueKey;
private Long monitoryPointId;
private int modelDivisionType;
private Long groupId;
private int type;
private int status;
private String serverHost;
private String data;
private int picWidth;
private int picHeight;
private String objects;
private Date alarmTime;
private Date createTime;
private boolean isRemove;
private Date removeTime;
}

接口:

import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;

public interface MonitorAlarmRepository extends ElasticsearchRepository<MonitorAlarmVO, Long> {

    //Page<MonitorAlarmVO> findByGroupId(Long groupId);

}

controller:

public class MonitorAlarmController {

    @Autowired
private MonitorAlarmRepository monitorAlarmRepository; //============================elasticsearch
/**
* 1、根据id查
* @param id
* @return
*/
@GetMapping("/esById/{id}")
public MonitorAlarmVO getBookById(@PathVariable Long id) {
return monitorAlarmRepository.findOne(id);
} /**
* 2、查 ++:全文检索(根据整个实体的所有属性,可能结果为0个)
* @param key
* @return
*/
@GetMapping("/esByKey/{key}")
public List<MonitorAlarmVO> testSearch(@PathVariable String key) {
QueryStringQueryBuilder builder = new QueryStringQueryBuilder(key);
Iterable<MonitorAlarmVO> searchResult = monitorAlarmRepository.search(builder);
Iterator<MonitorAlarmVO> iterator = searchResult.iterator();
List<MonitorAlarmVO> list = new ArrayList<MonitorAlarmVO>();
while (iterator.hasNext()) {
list.add(iterator.next());
}
return list;
} /**
* 3、查 +++:分页、分数、分域(结果一个也不少)
* @param page
* @param size
* @param q
* @return
* @return
*/
@GetMapping("/{page}/{size}/{key}")
public List<MonitorAlarmVO> searchCity(@PathVariable Integer page, @PathVariable Integer size, @PathVariable String key) { // 分页参数
Pageable pageable = new PageRequest(page, size); // 分数,并自动按分排序
FunctionScoreQueryBuilder functionScoreQueryBuilder = QueryBuilders.functionScoreQuery()
.add(QueryBuilders.boolQuery().should(QueryBuilders.matchQuery("name", key)),
ScoreFunctionBuilders.weightFactorFunction(1000)) // 权重:name 1000分
.add(QueryBuilders.boolQuery().should(QueryBuilders.matchQuery("message", key)),
ScoreFunctionBuilders.weightFactorFunction(100)); // 权重:message 100分 // 分数、分页
SearchQuery searchQuery = new NativeSearchQueryBuilder().withPageable(pageable)
.withQuery(functionScoreQueryBuilder).build(); Page<MonitorAlarmVO> searchPageResults = monitorAlarmRepository.search(searchQuery);
return searchPageResults.getContent(); } /**
* 4、增
* @param monitorAlarmVO
* @return
*/
@PostMapping("/esInsert")
public MonitorAlarmVO insertBook(MonitorAlarmVO monitorAlarmVO) {
monitorAlarmRepository.save(monitorAlarmVO);
return monitorAlarmVO;
} /**
* 5、删 id
* @param id
* @return
*/
@DeleteMapping("/esDelete/{id}")
public MonitorAlarmVO insertBook(@PathVariable Long id) {
MonitorAlarmVO monitorAlarmVO = monitorAlarmRepository.findOne(id);
monitorAlarmRepository.delete(id);
return monitorAlarmVO;
} /**
* 6、改
* @param monitorAlarmVO
* @return
*/
@PutMapping("/esUpdate")
public MonitorAlarmVO updateBook(MonitorAlarmVO monitorAlarmVO) {
monitorAlarmRepository.save(monitorAlarmVO);
return monitorAlarmVO;
} //============================elasticsearch
}

好的,我们启动试试,报了一个错误,提示如下:

threw exception; nested exception is java.lang.NoSuchMethodError: org.jboss.netty.channel.socket.nio.NioWorker
 
这个是因为我的项目里的dubbo/zookeeper的netty包和es的netty包冲突了导致启动不了,解决方法是排除其中一个的netty包,我这里选择排除dubbo和zookeeper的netty包试试,但是后面发现排除了netty包会导致dubbo出错,有两全其美的办法麻烦给我留言下。
如下:
        <dependency>
<groupId>com.alibaba.spring.boot</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<artifactId>netty</artifactId>
<groupId>org.jboss.netty</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.101tec</groupId>
<artifactId>zkclient</artifactId>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
<exclusion>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
<exclusion>
<groupId>io.netty</groupId>
<artifactId>netty</artifactId>
</exclusion>
</exclusions>
</dependency>

最后,我们可以启动项目,访问试试了。

 

spring-boot-starter-data-elasticsearch实现es的增删查改的更多相关文章

  1. Elasticsearch使用系列-ES增删查改基本操作+ik分词

    Elasticsearch使用系列-ES简介和环境搭建 Elasticsearch使用系列-ES增删查改基本操作+ik分词 一.安装可视化工具Kibana ES是一个NoSql数据库应用.和其他数据库 ...

  2. 从零开始开发一个Spring Boot Starter

    一.Spring Boot Starter简介 Starter是Spring Boot中的一个非常重要的概念,Starter相当于模块,它能将模块所需的依赖整合起来并对模块内的Bean根据环境( 条件 ...

  3. spring -boot s-tarter 详解

    Starter POMs是可以包含到应用中的一个方便的依赖关系描述符集合.你可以获取所有Spring及相关技术的一站式服务,而不需要翻阅示例代码,拷贝粘贴大量的依赖描述符.例如,如果你想使用Sprin ...

  4. 【spring boot】【elasticsearch】spring boot整合elasticsearch,启动报错Caused by: java.lang.IllegalStateException: availableProcessors is already set to [8], rejecting [8

    spring boot整合elasticsearch, 启动报错: Caused by: java.lang.IllegalStateException: availableProcessors ], ...

  5. SpringBoot 之Spring Boot Starter依赖包及作用

    Spring Boot 之Spring Boot Starter依赖包及作用 spring-boot-starter 这是Spring Boot的核心启动器,包含了自动配置.日志和YAML. spri ...

  6. Spring Boot Starter列表

    转自:http://blog.sina.com.cn/s/blog_798f713f0102wiy5.html Spring Boot Starter 基本的一共有43种,具体如下: 1)spring ...

  7. Spring Boot Starter 介绍

    http://www.baeldung.com/spring-boot-starters 作者:baeldung 译者:http://oopsguy.com 1.概述 依赖管理是任何复杂项目的关键部分 ...

  8. 手把手教你定制标准Spring Boot starter,真的很清晰

    写在前面 我们每次构建一个 Spring 应用程序时,我们都不希望从头开始实现具有「横切关注点」的内容:相反,我们希望一次性实现这些功能,并根据需要将它们包含到任何我们要构建的应用程序中 横切关注点 ...

  9. Spring Boot Starter自定义实现三步曲

    实现自定义的spring boot starter,只需要三步: 1.一个Bean 2.一个自动配置类 3.一个META-INF/spring.factories配置文件 下面用代码演示这三步. 项目 ...

随机推荐

  1. 【maven】---聚合和继承

    前言 自从我知道写maven实战这本书的作者长得随心所欲后,我再拿起这本书真心的不想看前言了.下面分享一下maven中的所谓的聚合和继承. 内容 下文中的子本指的是:多个maven项目. 父本指的是: ...

  2. 【转】ListBox Dock Fill 总是有空隙的问题

    源地址:https://www.cnblogs.com/norsd/p/6359291.html ListBox Dock设置了Fill, Right等 设计界面如己所愿,但是实际运行时,底部总是有不 ...

  3. [ActionScript 3.0] 使TextField呈现手型的简单方法

    有的人不知道这个方法,有时候为了给文本添加手型做了很多复杂的工作,虽然是可以实现,但心里有没有一种难以接受的感觉?那我们看看这个吧, 例子一看就懂: var str:String="显示手形 ...

  4. [ActionScript 3.0] 动态链接库

    很多时候,我们为了项目和程序结构更加清晰,需要将发布好的swf放到一个固定的地方供主文件引用,这时就会出现发布好的swf所用的as类路径发生改变,为避免这个问题,需要用到动态链接库,以下做一个简单例子 ...

  5. Flask 发布 1.0 稳定版

    简评:现在都开始版本大跃进了吗?对,别看别人,说的就是你 pipenv(名单太长,待补齐...) Flask 其实早就已经十分稳定了,而在第一个 commit 大概 8 年之后,版本号才最终反映出了这 ...

  6. React-Native 工程添加推送功能 (iOS 篇)

    推送已经是是手机应用的基本功能,如果自己实现一套推送系统费时费力,所有一般我们会使用第三方的推送服务,这里我使用「极光推送」作为集成推送的例子,因为有现成的 react native 插件 jpush ...

  7. loj #6515. 「雅礼集训 2018 Day10」贪玩蓝月

    \(\color{#0066ff}{输入样例}\) 0 11 10 QU 0 0 QU 1 9 IG 14 7 IF 3 5 QU 0 9 IG 1 8 DF QU 0 4 IF 1 2 DG QU ...

  8. css第二篇:样式的特殊性、重要性、继承和层叠

    特殊性:   假设有几个不同的规则改变的都是同一个元素的值,那么哪一个规则将会胜出呢?这就得靠特殊值啦,什么是特殊值呢?特殊值的大小呢?如下图: 值越大代表越牛,如1,0,0,0永远大于0,X,X,X ...

  9. js获取窗口宽度、高度

    1.获取屏幕的高度和宽度(屏幕分辨率): window.screen.height window.screen.width 2.获取屏幕工作区域的高度和宽度(去掉状态栏): window.screen ...

  10. 反弹shell集锦

    1.   关于反弹shell 就是控制端监听在某TCP/UDP端口,被控端发起请求到该端口,并将其命令行的输入输出转到控制端.reverse shell与telnet,ssh等标准shell对应,本质 ...