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 。
但是如果你的数据里面不止一只小狗满足条件名字叫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开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
难道这样就够了吗?不,远远不够!
提前多熟悉阿里往年的面试题肯定是对面试有很大的帮助的,但是作为技术性职业,手里有实打实的技术才是你面对面试官最有用的利器,这是从内在散发出来的自信。
备战阿里时我花的最多的时间就是在学习技术上,占了我所有学习计划中的百分之70,这是一些我学习期间觉得还是很不错的一些学习笔记
我为什么要写这篇文章呢,其实我觉得学习是不能停下脚步的,在网络上和大家一起分享,一起讨论,不单单可以遇到更多一样的人,还可以扩大自己的眼界,学习到更多的技术,我还会在csdn、博客、掘金等网站上分享技术,这也是一种学习的方法。
今天就分享到这里了,谢谢大家的关注,以后会分享更多的干货给大家!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
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
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!文章来源地址https://www.toymoban.com/news/detail-855787.html
到了这里,关于Springboot 整合ElasticSearch 常用的插入查询,模糊查询,范围查询的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!