IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> SpringBoot 集成Elasticsearch -> 正文阅读

[Java知识库]SpringBoot 集成Elasticsearch

?????????Elasticsearch是一个开源的高扩展的分布式全文检索引擎,它可以近乎实时的存储、检索数据;本身扩展性很好,可以扩展到上百台服务器,处理PB级别的数据。?
Elasticsearch也使用Java开发并使用Lucene作为其核心来实现所有索引和搜索的功能,但是它的目的是通过简单的RESTful API来隐藏Lucene的复杂性,从而让全文搜索变得简单。

1.安装Elasticsearch服务并进行相关配置,启动Elasticsearch服务

2. 安装Elasticsearch Header? 可视查看相关记录信息

3. pom.xml

<!-- elasticsearch -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>
<dependency>
    <groupId>io.searchbox</groupId>
    <artifactId>jest</artifactId>
</dependency

1.application.yml

spring:
  elasticsearch:
    jest:
      uris:
        - http://124.222.108.169:9200
      read-timeout: 5000

2.StudentController

**
 *
 */
@Slf4j
@RestController
@RequestMapping("/student")
@Api(tags = "学生信息")
public class StudentController {
    @Autowired
    private StudentService studentService;


    @ApiOperation(value = "保存学生数据")
    @RequestMapping(path="/saveStudent")
    public JSONResult saveStudent( HttpServletRequest request, HttpServletResponse response){

        List<Student> list=new ArrayList<Student>();
        Student student=new Student( 1L,"张三",5);
        list.add(student);
        student=new Student( 2L,"王五",8);
        list.add(student);
        student=new Student( 4L,"赵六",10);
        list.add(student);
        studentService.saveEntity(list);
        return  JSONResult.ok();
    }


    @ApiOperation(value = "删除学生数据")
    @RequestMapping(path="/delStudent")
    public JSONResult delStudent( HttpServletRequest request, HttpServletResponse response){
       String id=request.getParameter("id");
        studentService.delEntity(id);
        return  JSONResult.ok();
    }



    @ApiOperation(value = "搜索")
    @RequestMapping(path="/searchStudent")
    public JSONResult searchStudent( HttpServletRequest request){
        List<Student>  result=studentService.searchEntity("张");
        return  JSONResult.ok(result);
    }


    /**
     * 创建索引
     * @param indexName
     * @throws Exception
     */
    @ApiOperation(value = "创建索引")
    @RequestMapping(path="/createIndex")
    public JSONResult createIndex(@RequestParam("indexName")String indexName) throws Exception{
        studentService.createIndex(indexName);
        return JSONResult.ok();
    }

    /**
     * 删除索引
     * @param indexName
     * @throws Exception
     */
    @ApiOperation(value = "刪除索引")
    @RequestMapping(path="/deleteIndex")
    public JSONResult deleteIndex(@RequestParam("indexName")String indexName) throws Exception{
        studentService.deleteIndex(indexName);
        return JSONResult.ok();
    }
}

3.StudentServiceImpl

@Service
public class StudentServiceImpl implements StudentService {

    private static final Logger LOGGER = LoggerFactory.getLogger(StudentServiceImpl.class);

    @Autowired
    private JestClient jestClient;

    @Override
    public void saveEntity(Student entity) {
        Index index = new Index.Builder(entity).index(Student.INDEX_NAME).type(Student.TYPE).build();
        try {
            jestClient.execute(index);
            LOGGER.info("插入完成");
        } catch (IOException e) {
            e.printStackTrace();
            LOGGER.error(e.getMessage());
        }
    }

    @Override
    public void delEntity(String id) {
        Delete index = new Delete.Builder(id).index(Student.INDEX_NAME).type(Student.TYPE).build();
        try {
            jestClient.execute(index);
            LOGGER.info("删除完成");
        } catch (IOException e) {
            e.printStackTrace();
            LOGGER.error(e.getMessage());
        }
    }




    @Override
    public void saveEntity(List<Student> entityList) {
        Bulk.Builder bulk = new Bulk.Builder();
        for(Student entity : entityList) {
            Index index = new Index.Builder(entity).id(String.valueOf(entity.getId())).index(Student.INDEX_NAME).type(Student.TYPE).build();
            bulk.addAction(index);
        }
        try {
            jestClient.execute(bulk.build());
            LOGGER.info("批量插入完成");
        } catch (IOException e) {
            e.printStackTrace();
            LOGGER.error(e.getMessage());
        }
    }

    /**
     * 在ES中搜索内容
     */
    @Override
    public List<Student> searchEntity(String searchContent){
        SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
        searchSourceBuilder.query(QueryBuilders.matchQuery("studentName",searchContent));
        Search search = new Search.Builder(searchSourceBuilder.toString())
                .addIndex(Student.INDEX_NAME).addType(Student.TYPE).build();
        try {
            JestResult result = jestClient.execute(search);
            return result.getSourceAsObjectList(Student.class);
        } catch (IOException e) {
            LOGGER.error(e.getMessage());
            e.printStackTrace();
        }
        return null;
    }


    /**
     * 创建索引
     * @param indexName
     *
     */
    @Override
    public void createIndex(String indexName) {
        try{
            CreateIndex createIndex = new CreateIndex.Builder(indexName).build();
            JestResult result = jestClient.execute(createIndex);
            LOGGER.info("result",result.getJsonString());
        }catch (Exception e){
            LOGGER.error(e.getMessage());
            e.printStackTrace();
        }
    }

    /**
     * 删除索引
     * @param indexName
     *
     */
    @Override
    public void deleteIndex(String indexName) {
        try{
            DeleteIndex deleteIndex = new DeleteIndex.Builder(indexName).build();
            JestResult result = jestClient.execute(deleteIndex);
            LOGGER.info("result",result.getJsonString());
        }catch (Exception e){
            LOGGER.error(e.getMessage());
            e.printStackTrace();
        }

    }

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-03-13 21:36:26  更:2022-03-13 21:40:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 9:35:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码