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

完成我们日常需要使用的:

1. 单数据插入

2.批量数据插入

3.单个查询

4.查询所有

5.删除

6.条件查询(范围查询,精确查询,模糊查询)

ElasticsearchRepository 其实就跟JPA的使用是一样的,而且里面包含的方法非常非常多,我简单做了个图:

分享,不仅是为了他人,更是为了自己。

正文

======

不废话我们开始进入实践教程,

这次我们采取 小狗作为例子。

新建实体类,Dog.java:

import lombok.Data;

import org.springframework.data.elasticsearch.annotations.Document;

/**

  • @Author : JCccc

  • @CreateTime : 2020/3/12

  • @Description :

**/

@Data

@Document(indexName = “pets”, type = “dog”)

public class Dog {

private String id;

private String name;

private Integer age;

private String color;

}

然后是对接数据层,也就是该篇的使用核心ElasticsearchRepository , 新建DogRepository.java:

import com.example.elastucsearchdemo.pojo.Dog;

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

import org.springframework.stereotype.Repository;

/**

  • @Author : JCccc

  • @CreateTime : 2020/3/13

  • @Description :

**/

@Repository

public interface DogRepository extends ElasticsearchRepository<Dog, String> {

}

然后是service和 impl,

新建DogService.java :

import com.example.elastucsearchdemo.pojo.Dog;

import java.util.List;

/**

  • @Author : JCccc

  • @CreateTime : 2020/5/12

  • @Description :

**/

public interface DogService {

/**

  • 删除

  • @param id

  • @return

*/

boolean deleteDog(String id) ;

/**

  • 插入

  • @param dog

  • @return

*/

Dog saveDog(Dog dog) ;

/**

  • 批量插入

  • @param dogsList

  • @return

*/

Boolean saveDogAll(List dogsList) ;

/**

  • 查询所有小狗

  • @return

*/

List findAllDog() ;

/**

  • 查询一只小狗

  • @return

*/

Dog findOneDog(String id) ;

}

新建DogServiceImpl.impl:

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.stereotype.Service;

import java.util.ArrayList;

import java.util.List;

import java.util.Optional;

/**

  • @Author : JCccc

  • @CreateTime : 2020/5/12

  • @Description :

**/

@Service

public class DogServiceImpl implements DogService {

@Autowired

private DogRepository repository;

public boolean deleteDog(String id) {

try {

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);

}

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

批量数据插入:

@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);

}

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

删除:

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

@GetMapping(“deleteOne”)

public void deleteOne() {

dogService.deleteDog(“62668f83be6440b493d761dfc2703683”);

}

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

查找单条数据:

@GetMapping(“findTest”)

public void find() {

//根据ID 查找一只小狗

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

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

}

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

查找所有数据:

@GetMapping(“findAll”)

public void find() {

//查找所有小狗

List allDog = dogService.findAllDog();

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

}

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

修改 :

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

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

我们把里面的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);

}

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

接下来是着重讲下查询,

精确查询:

查找 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());

}

调用下该接口:

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

总结

本文从基础到高级再到实战,由浅入深,把MySQL讲的清清楚楚,明明白白,这应该是我目前为止看到过最好的有关MySQL的学习笔记了,我相信如果你把这份笔记认真看完后,无论是工作中碰到的问题还是被面试官问到的问题都能迎刃而解!

MySQL50道高频面试题整理:

576.png)

接下来是着重讲下查询,

精确查询:

查找 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());

}

调用下该接口:

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

总结

本文从基础到高级再到实战,由浅入深,把MySQL讲的清清楚楚,明明白白,这应该是我目前为止看到过最好的有关MySQL的学习笔记了,我相信如果你把这份笔记认真看完后,无论是工作中碰到的问题还是被面试官问到的问题都能迎刃而解!

MySQL50道高频面试题整理:

[外链图片转存中…(img-7d19ShjP-1718777685545)]

  • 22
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值