当前位置: 首页 > wzjs >正文

有那些专门做职业统计的网站网页制作培训教程

有那些专门做职业统计的网站,网页制作培训教程,中铁建设门户网入口,网页设计欣赏及点评前言: 上一篇我们简单分享了 Elasticsearch 的一些概念性的知识,本篇我们来分享 Elasticsearch 的实际运用,也就是在 Spring Booot 项目中使用 Elasticsearch。 Elasticsearch 系列文章传送门 Elasticsearch 基础篇【ES】 Elasticsearch …

前言:

上一篇我们简单分享了 Elasticsearch 的一些概念性的知识,本篇我们来分享 Elasticsearch 的实际运用,也就是在 Spring Booot 项目中使用 Elasticsearch。

Elasticsearch 系列文章传送门

Elasticsearch 基础篇【ES】

Elasticsearch Windows 环境安装

Elasticsearch 之 ElasticsearchRestTemplate 普通查询

Elasticsearch 之 ElasticsearchRestTemplate 聚合查询

Elasticsearch 之 ElasticsearchRestTemplate 嵌套聚合查询【嵌套文档聚合查询】

Elasticsearch 深入分析三种分页查询【Elasticsearch 深度分页】

引入 Elasticsearch 依赖

Spring Boot 集成 Elasticsearch 的第一步就是引入 Elasticsearch 的依赖,如下:

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.4.5</version><relativePath/> <!-- lookup parent from repository -->
</parent><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId><version>2.6.0</version>
</dependency>

配置文件配置

在 properties 文件中进行 Elasticsearch 配置,如下:

spring.elasticsearch.rest.uris= localhost:9200
spring.elasticsearch.rest.username=
spring.elasticsearch.rest.password=

我这里没有配置账号密码,因此账号密码为空。

定义数据实体

我这里使用一个用户 User 对象进行一个简单的实体定义,代码如下:

package com.order.service.entity.elasticsearch;import lombok.Data;
import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;/*** @ClassName: elasticsearch* @Author: Author* @Date: 2024/12/22 19:25* @Description:*/
@Data
@Document(indexName = "user")
public class UserDO {@Idprivate int id;private String userName;private int age;}

Repository 定义

这里我们先采用继承 ElasticsearchRepository 接口的方式完成 Elasticsearch 的增删改查,代码如下:

package com.order.service.mapper;import com.order.service.entity.elasticsearch.UserDO;
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;/*** @ClassName: ElasticsearchUserMapper* @Author: Author* @Date: 2024/12/22 19:33* @Description:*/
public interface ElasticsearchUserRepository extends ElasticsearchRepository<UserDO,String> {}

Service 定义

我们在 Service 中定义了增删改查的方法,代码如下:

package com.order.service.service;import com.order.service.entity.elasticsearch.UserDO;import java.util.List;/*** @ClassName: ElasticsearchService* @Author: Author* @Date: 2024/12/22 19:27* @Description:*/
public interface ElasticsearchService {/*** @param userDO:* @date 2024/12/19 10:39* @description 保存用户*/void saveUser(UserDO userDO);/*** @param id:* @return com.order.service.entity.elasticsearch.UserDO* @date 2024/12/23 19:39* @description 查询用户*/UserDO queryUserById(int id);/*** @date 2024/12/23 19:40* @description 更新用户*/void updateUser(UserDO userDO);/*** @param id:* @author Author* @date 2024/12/19 10:41* @description 删除用户*/void deleteUserById(int id);/*** @return java.util.List<com.order.service.entity.elasticsearch.UserDO>* @author Author* @date 2024/12/23 19:42* @description 查询所有用户*/List<UserDO> queryAllUser();}

ServiceImpl 定义

我们在 ServiceImpl 中定义了实现了 Service 的增删改查的方法,通过注入 ElasticsearchUserRepository 的方式完成了 Elasticsearch 的增删改查,代码如下:

package com.order.service.service.impl;import com.order.service.entity.elasticsearch.UserDO;
import com.order.service.mapper.ElasticsearchUserRepository;
import com.order.service.service.ElasticsearchService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.util.ArrayList;
import java.util.List;
import java.util.Optional;/*** @ClassName: ElasticsearchServiceImpl* @Author: Author* @Date: 2024/12/22 19:34* @Description:*/
@Slf4j
@Service
public class ElasticsearchServiceImpl implements ElasticsearchService {@Autowiredprivate ElasticsearchUserRepository elasticsearchUserRepository;@Overridepublic void saveUser(UserDO userDO) {elasticsearchUserRepository.save(userDO);}@Overridepublic UserDO queryUserById(int id) {Optional<UserDO> optional = elasticsearchUserRepository.findById(String.valueOf(id));return optional.get();}@Overridepublic void updateUser(UserDO userDO) {elasticsearchUserRepository.save(userDO);}@Overridepublic void deleteUserById(int id) {elasticsearchUserRepository.deleteById(String.valueOf(id));}@Overridepublic List<UserDO> queryAllUser() {Iterable<UserDO> all = elasticsearchUserRepository.findAll();List<UserDO> userList = new ArrayList<>();for (UserDO userDO : all) {userList.add(userDO);}return userList;}
}

Controller 定义

我们在 Controller 的方式完成 Elasticsearch 的增删改查测试,代码如下:

package com.order.service.controller;import com.order.service.entity.elasticsearch.UserDO;
import com.order.service.service.ElasticsearchService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;import java.util.List;/*** @ClassName: ElasticsearchContorller* @Author: Author* @Date: 2024/12/22 19:26* @Description:*/
@Slf4j
@RestController
public class ElasticsearchController {@Autowiredprivate ElasticsearchService elasticsearchService;@PostMapping("/save-user")public String saveUser(@RequestBody UserDO userDO) {elasticsearchService.saveUser(userDO);return "success";}@GetMapping("/query-user-by-id")public UserDO queryUserById(@RequestParam int id) {return elasticsearchService.queryUserById(id);}@PostMapping("/update-user")public String updateUser(@RequestBody UserDO userDO) {elasticsearchService.updateUser(userDO);return "success";}@GetMapping("/detele-user-by-id")public String deleteUserById(@RequestParam int id) {elasticsearchService.deleteUserById(id);return "success";}@GetMapping("/query-all-user")public List<UserDO> queryUserById() {return elasticsearchService.queryAllUser();}}

Elasticsearch 增删改查测试

新增用户测试,如下:

在这里插入图片描述
正常写入了,结果符合预取,下面我们试试查询。

查询用户测试,如下:

在这里插入图片描述
查询到了我们各个新增的用户,结果符合预期,下面我们来试试更新用户信息。

更新用户测试,如下:

在这里插入图片描述

更新用户信息成功,我们再次查询该用户信息,看看是否真的更新成功了。

再次查询用户信息如下:

在这里插入图片描述

可以看到用户的姓名和年龄都发生了变更,表示我们更新成功了,结果符合预期。

删除用户测试,如下:

在这里插入图片描述

删除用户信息成功,我们再次查询该用户信息,看看是否真的删除成功了。

再次查询用户信息如下:

在这里插入图片描述

可以看到没有查询到用户信息表名息删除成功。

查询所有用户测试,如下:

在这里插入图片描述

可以看到返回了一个用户信息列表,结果符合预期。

总结:可以看到我们使用 ElasticsearchRepository(也就是 JPA) 进程 Elasticsearch 的数据增删改查就像使用 MySQL 一样简单,但我在尝试使用较为复杂的查询的时候,ElasticsearchRepository 相关的方法提示已经过期,下一篇我们将分享使用 ElasticsearchRestTemplate 实现复杂查询,希望本篇的分享可以帮助到有需要的朋友。

如有不正确的地方欢迎各位指出纠正。

http://www.dtcms.com/wzjs/151952.html

相关文章:

  • 移动网站开发工具拼多多代运营一般多少钱
  • 湛江企业建站程序成品网站建站空间
  • 深圳市建设主管部门门户网站做网站用什么编程软件
  • 为什么需要网站开发seo百度网站排名软件
  • 网络宣传推广策划范文seo研究院
  • 做热区的网站收录优美图片app
  • 沈阳公司建设网站互联网行业都有哪些工作
  • 网站规划怎么做百度一下你就知道首页
  • 国家建设执业注册中心网站seo外链软件
  • 诸暨做网站广告的电话seo的最终是为了达到
  • 做oa系统的网站好项目推荐平台
  • 绿色网站模板手机导航下载2022新版
  • 广告设计与制作专业就业方向个人seo外包
  • 高端产品网站友情链接交易网站
  • 做网站需要投入多少钱seo外链优化策略
  • 网站动图怎么做最好的推广平台是什么软件
  • 网站做建筑三维图百度商业平台官网
  • 运城哪家做网站的公司好企业网站seo公司
  • 个人网站做公司网站制作网页的流程步骤
  • 档案网站建设现状分析百度百科分类方法
  • 杭州网站建设的公司网页设计素材
  • 北京律师网站建设推荐网络营销服务公司
  • 网站背景怎么做网络推广渠道都有哪些
  • 全国企业信息查询网站长春网长春关键词排名站设计
  • 商务网站开发考题百度域名提交收录网址
  • 网站制作什么样的字体好看在线友情链接
  • wordpress图片主题下载失败网络优化seo是什么工作
  • 自己做的网站可以开直播电商平台开发需要多少钱
  • 中小企业还需要网站吗自媒体平台注册官网下载
  • 做网站运营需要学什么网红推广团队去哪里找