Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询

这篇具有很好参考价值的文章主要介绍了Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

repository.deleteById(id);

} catch (Exception ex) {

ex.printStackTrace();

return false;

}

return true;

}

public Dog saveDog(Dog dog) {

try {

Dog save = repository.save(dog);

System.out.println(“结果:”+save.toString());

return save;

} catch (Exception ex) {

ex.printStackTrace();

return null;

}

}

public Boolean saveDogAll(List dogsList) {

try {

repository.saveAll(dogsList);

} catch (Exception ex) {

ex.printStackTrace();

return false;

}

return true;

}

/**

  • 查询所有小狗

  • @return

*/

public List findAllDog() {

List list = new ArrayList<>();

try {

Iterable aIterable = repository.findAll();

for (Dog Dog : aIterable) {

list.add(Dog);

}

} catch (Exception ex) {

ex.printStackTrace();

return null;

}

return list;

}

/**

  • 查询所有小狗

  • @return

*/

public Dog findOneDog(String id) {

Optional resu = repository.findById(id);

return repository.findById(id).get();

}

}

接着我们来写个简单的接口验证一下这些常规crud.

新建DogController.java:

import com.example.elastucsearchdemo.pojo.Dog;

import com.example.elastucsearchdemo.repository.DogRepository;

import com.example.elastucsearchdemo.service.DogService;

import org.elasticsearch.index.query.QueryBuilder;

import org.elasticsearch.index.query.QueryBuilders;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.bind.annotation.PostMapping;

import org.springframework.web.bind.annotation.RestController;

import java.util.ArrayList;

import java.util.List;

import java.util.Random;

/**

  • @Author : JCccc

  • @CreateTime : 2020/5/12

  • @Description :

**/

@RestController

public class DogController {

@Autowired

DogService dogService;

public static String getNonceStr(int length) {

//生成随机字符串

String str = “zxcvbnmlkjhgfdsaqwertyuiopQWERTYUIOPASDFGHJKLZXCVBNM1234567890”;

Random random = new Random();

StringBuffer randomStr = new StringBuffer();

// 设置生成字符串的长度,用于循环

for (int i = 0; i < length; ++i) {

//从62个的数字或字母中选择

int number = random.nextInt(62);

//将产生的数字通过length次承载到sb中

randomStr.append(str.charAt(number));

}

//将承载的字符转换成字符串

return randomStr.toString();

}

}

单条数据插入:

@PostMapping(“addDogTest”)

public void addTest() {

//插入一只小狗

Dog dog = new Dog();

dog.setId(“100111”);

dog.setName(“TestDog”);

dog.setAge(3);

dog.setColor(“black”);

dogService.saveDog(dog);

}

调用该接口,可以看到数据成插入:

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

批量数据插入:

@PostMapping(“addListTest”)

public void addTest() {

//插入所有小狗

List dogsList = new ArrayList<>();

for (int i = 0; i < 5; i++) {

Dog dogPes = new Dog();

dogPes.setId(UUID.randomUUID().toString().replace(“-”, “”));

dogPes.setName(“Alaska-”+getNonceStr(4));

dogPes.setAge(new Random().nextInt(100));

dogPes.setColor(“red”);

dogsList.add(dogPes);

}

dogService.saveDogAll(dogsList);

}

调用该接口,可以看到数据成插入:

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

删除:

我们就把这个id为62668f83be6440b493d761dfc2703683的进行删除,

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

@GetMapping(“deleteOne”)

public void deleteOne() {

dogService.deleteDog(“62668f83be6440b493d761dfc2703683”);

}

调用下这个接口,可以看到数据已经删掉:

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

查找单条数据:

@GetMapping(“findTest”)

public void find() {

//根据ID 查找一只小狗

Dog oneDog = dogService.findOneDog(“91713fd657ee4a059811bfb7df7456d0”);

System.out.println(oneDog.toString());

}

调用下该接口,可以看到数据成功获取:

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

查找所有数据:

@GetMapping(“findAll”)

public void find() {

//查找所有小狗

List allDog = dogService.findAllDog();

System.out.println(allDog.toString());

}

调用下该接口,可以看到数据成功获取:

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

修改 :

可以看到service里面其实没有修改方法,如果用过JPA的小伙伴应该不能理解,因为这里的修改其实可以通过插入(保存)实现,也就是根据id去修改。

可以看到我们最早插入的数据,id为 100111:

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

我们把里面的age,和name 都修改下,通过插入去修改:

@PostMapping(“updateDogTest”)

public void updateDogTest() {

//插入一只小狗

Dog dog = new Dog();

dog.setId(“100111”);

dog.setName(“update”);

dog.setAge(2);

dog.setColor(“black”);

dogService.saveDog(dog);

}

调用下该接口,可以看到数据修改成功:

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

接下来是着重讲下查询,

精确查询:

查找 name(字符串)作为字段,值为Alaska-km6u 的数据。

@Autowired

DogRepository repository; //为了方便讲解,就直接先这样使用

@GetMapping(“queryTest”)

public void queryTest() {

QueryBuilder qb0 = QueryBuilders.termQuery(“name”+“.keyword”, “Alaska-km6u”);

QueryBuilder qb = QueryBuilders.boolQuery().must(qb0);

List list=new ArrayList<>();

Iterable aIterable = repository.search(qb);

for (Dog Dog : aIterable) {

list.add(Dog);

}

System.out.println(list.toString());

}

调用下该接口:

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

注意,如果你是要精确查找一条数据,那么就是termQuery

但是如果你的数据里面不止一只小狗满足条件名字叫Alaska-km6u ,那就需要使用 termsQuery

范围查询:

rangeQuery

假如我们要查询 age在 12-20岁之间的小狗,

那么就是:

// 闭区间

QueryBuilder qb1 = QueryBuilders.rangeQuery(“age”).from(“12”).to(“20”);

QueryBuilder qb = QueryBuilders.boolQuery().must(qb1);

List list=new ArrayList<>();

Iterable aIterable = repository.search(qb);

for (Dog Dog : aIterable) {

list.add(Dog);

}

System.out.println(list.toString());

开区间:

//开区间

QueryBuilder qb1 = QueryBuilders.rangeQuery(“age”).from(“12”, false).to(“20”, false);

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

难道这样就够了吗?不,远远不够!

提前多熟悉阿里往年的面试题肯定是对面试有很大的帮助的,但是作为技术性职业,手里有实打实的技术才是你面对面试官最有用的利器,这是从内在散发出来的自信。

备战阿里时我花的最多的时间就是在学习技术上,占了我所有学习计划中的百分之70,这是一些我学习期间觉得还是很不错的一些学习笔记

我为什么要写这篇文章呢,其实我觉得学习是不能停下脚步的,在网络上和大家一起分享,一起讨论,不单单可以遇到更多一样的人,还可以扩大自己的眼界,学习到更多的技术,我还会在csdn、博客、掘金等网站上分享技术,这也是一种学习的方法。

今天就分享到这里了,谢谢大家的关注,以后会分享更多的干货给大家!

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询,程序员,spring boot,elasticsearch,jenkins

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
ges/e5c14a7895254671a72faed303032d36.jpg" alt=“img” style=“zoom: 33%;” />

难道这样就够了吗?不,远远不够!

提前多熟悉阿里往年的面试题肯定是对面试有很大的帮助的,但是作为技术性职业,手里有实打实的技术才是你面对面试官最有用的利器,这是从内在散发出来的自信。

备战阿里时我花的最多的时间就是在学习技术上,占了我所有学习计划中的百分之70,这是一些我学习期间觉得还是很不错的一些学习笔记

我为什么要写这篇文章呢,其实我觉得学习是不能停下脚步的,在网络上和大家一起分享,一起讨论,不单单可以遇到更多一样的人,还可以扩大自己的眼界,学习到更多的技术,我还会在csdn、博客、掘金等网站上分享技术,这也是一种学习的方法。

今天就分享到这里了,谢谢大家的关注,以后会分享更多的干货给大家!

[外链图片转存中…(img-C0HdVXVU-1712680677652)]

[外链图片转存中…(img-65hygU75-1712680677653)]

[外链图片转存中…(img-HYFYtesE-1712680677653)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!文章来源地址https://www.toymoban.com/news/detail-855787.html

到了这里,关于Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Springboot集成ElasticSearch实现简单的crud、简单分页、模糊查询

    pom.xml引入ElasticSearch application.yml配置 启动类加入注解@EnableElasticsearchRepositories ElasticSearchEntity Repository类继承ElasticsearchRepository ElasticSearchService ElasticSearchController 测试 查看创建的索引(相当于MySQL的表) method:GET 删除索引 method:DELETE 查看索引里的全部数据, elastic是实体类

    2023年04月18日
    浏览(49)
  • Springboot整合Elasticsearch 7.X 复杂查询

    这里使用Springboot 2.7.12版本,Elasticsearch为7.15.0。 导入依赖 yaml文件配置: 构建实体类,这里为商品的SKU属性表 构建service层进行复杂查询:指定条件查询,聚合查询,分页查询,排序查询,高亮等等 接口测试: 查询如下:      

    2024年02月03日
    浏览(38)
  • Springboot整合Elasticsearch新版分页查询

    其它插入、删除、简单查询都可以通过Repository调用方法查询。 Elasticsearch现在的新版本已经弃用了ElasticsearchTemplate类,Repository里原来的search方法也已经弃用了。下面是使用ElasticsearchRestTemplate类实现的分页查询 代码

    2024年02月11日
    浏览(37)
  • springboot整合elasticsearch8组合条件查询

    整合过程见上一篇文章 springboot整合elasticsearch8 1.es8多条件组合查询 2.使用scroll进行大数据量查询

    2024年02月16日
    浏览(52)
  • SpringBoot整合ElasticSearch实现分页查询

    本文使用SpringBoot整合ElasticSearch实现分页查询 还是继续使用spring-boot-starter-data-elasticsearch来实现分页查询操作 数据准备 使用ElasticsearchRestTemplate来实现 程序结果 使用ElasticsearchOperations来实现 程序结果 本文记录了SpringBoot整合ElasticSearch来实现分页查询的两种方式

    2024年01月25日
    浏览(48)
  • ElasticSearch系列 - SpringBoot整合ES:组合多个查询条件 bool 查询

    01. ElasticSearch 布尔查询是什么? 在实际应用中,我们很有可能会查询多个值或字段。 一个 bool 查询由三部分组成: must:所有的语句都必须(must) 匹配,与 AND 等价。 must_not:所有的语句都不能(must not)匹配,与 NOT 等价。 should:至少有一个语句要匹配,与 OR 等价。 02.

    2023年04月08日
    浏览(72)
  • springboot整合Activiti-常用方法(部署、启动、查询、执行任务)

    ps:activiti7强依赖security,所以还需要整合security,这里就当整合成功了。 真不会整合,就看我下面这个博文 日常记录-SpringBoot整合SpringSecurity(前后分离)+JWT+Redis 启动成功后就看到下面的表 activiti7默认不生成act_hi历史表 如果不生成历史表,还需要禁用插入历史数据【sprin

    2024年01月20日
    浏览(37)
  • springboot整合elasticsearch实现类似于mysql的like查询

    目录 一、ES分页查询常用方式 二、引入es的依赖 三、es配置文件 四、es工具类 五、分页查询示例 1.from + size from表示从第几行开始,size表示查询多少条文档。from默认为0,size默认为10,最灵活的分页方式。 2.scroll 不适合用来做实时搜索,而更适用于后台批处理任务,如日志导

    2023年04月09日
    浏览(36)
  • ElasticSearch序列 - SpringBoot整合ES:根据指定的 ids 查询

    1. ElasticSearch 根据 ids 查询文档 ① 索引文档,构造数据 ② 查询文档 id 为 1 或者 2 的文档: 我们索引文档时,文档的id为整型,为什么查询出来的文档 id为字符串类型呢?如果我们使用字符串类型的文档id查询呢? 可以看到仍然可以查询到匹配的文档。 在Elasticsearch中,文档

    2024年02月11日
    浏览(55)
  • ElasticSearch系列 - SpringBoot整合ES:多个精确值查询 terms

    ElasticSearch - SpringBoot整合ES:多个精确值查询 terms 01. ElasticSearch terms 查询支持的数据类型 在Elasticsearch中,terms查询支持多种数据类型,包括: 字符串类型:可以将多个字符串值作为数组传递给terms查询,以匹配包含任何一个指定字符串值的文档。 数值类型:可以将多个数值作

    2024年02月16日
    浏览(69)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包