elasticsearch数据存储结构,springboot集成elasticsearch
创始人
2024-02-21 13:52:52
0

一、数据存储结构

在这里插入图片描述
结合数据库的结构理解起来就会比较清楚:
1)索引(Index)=>数据库(Database)。
2)类型(Type)=>表(Table)。
3)文档(Document)=>表中的一行记录(Row)。
4)属性(Field)=>字段列(Column)。

  1. 索引索引是含义相同的属性文档的集合,是Elasticsearch的一个逻辑存储,可以理解为关系型数据库中的数据库。
  2. 类型文档可以分组,比如员工信息。这种分组就叫类型,它是虚拟的逻辑分组,用来过滤文档数据。
  3. 文档文档是可以被索引的基本数据单位,存储在Elasticsearch中的主要实体叫文档,可以理解为关系型数据库中表的一行记录。

二、springboot集成elasticsearch

1.安装elasticsearch
ES的安装环境最好是类Linux操作系统,本书中使用mac。从ES 7.x版本开始,其发行的安装包中就已经内置了JDK。如果用户对JDK有独特的要求,可以修改其启动脚本进行依赖配置。为简单起见,本节安装ES时使用内置的JDK。
brew安装jdk8
安装brew包管理工具,就可以直接命令安装es
es安装步骤、这个我失败了,我用下面的步骤成功
es安装步骤
es启动失败,指定es启动jdk版本
https://www.cnblogs.com/blogxiao/p/16900204.html
上面的博客我都安装失败了
我安装成功用的这个方法
启动后无法访问
在这里插入图片描述Linux系统安装,参考这本书
在这里插入图片描述
2.引入依赖

org.springframework.bootspring-boot-starter-data-elasticsearch

在这里插入图片描述3.配置连接地址
在这里插入图片描述

spring.elasticsearch.rest.uris=http://127.0.0.1:9200

4.创建文档对象
创建实体对象类Book,然后使用@Document注解定义文档对象,示例代码如下:

package com.yangjunbo.JPADemo.pojo;import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;
import org.springframework.data.elasticsearch.annotations.Field;
import org.springframework.data.elasticsearch.annotations.FieldType;@Document( indexName = "book" , replicas = 0)
public class Book {@Idprivate Long id;@Field(analyzer = "ik_max_word",type = FieldType.Text)private String bookName;@Field(type = FieldType.Keyword)private String author;private float price;private int page;@Field(type = FieldType.Keyword, fielddata = true)private String category;// 省略get、set方法public Long getId() {return id;}public void setId(Long id) {this.id = id;}public String getBookName() {return bookName;}public void setBookName(String bookName) {this.bookName = bookName;}public String getAuthor() {return author;}public void setAuthor(String author) {this.author = author;}public float getPrice() {return price;}public void setPrice(float price) {this.price = price;}public int getPage() {return page;}public void setPage(int page) {this.page = page;}public String getCategory() {return category;}public void setCategory(String category) {this.category = category;}public Book(){}public Book(Long id,String bookName, String author,float price,int page,String category) {this.id = id;this.bookName = bookName;this.author = author;this.price = price;this.page = page;this.category = category;}@Overridepublic String toString() {final StringBuilder sb = new StringBuilder( "{\"Book\":{" );sb.append( "\"id\":" ).append( id );sb.append( ",\"bookName\":\"" ).append( bookName ).append( '\"' );sb.append( ",\"page\":\"" ).append( page ).append( '\"' );sb.append( ",\"price\":\"" ).append( price ).append( '\"' );sb.append( ",\"category\":\"" ).append( category ).append( '\"' );sb.append( ",\"author\":\"" ).append( author ).append( '\"' );sb.append( "}}" );return sb.toString();}
}

在这里插入图片描述

5.创建操作的repository

package com.yangjunbo.JPADemo.repository;import com.yangjunbo.JPADemo.pojo.Book;
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;import java.util.List;public interface BookRepository extends ElasticsearchRepository {List findByBookNameLike(String bookName);
}

在这里插入图片描述

通过上面的示例代码,我们发现其使用方式和JPA的语法是一样的。

6.创建测试方法测试

package com.yangjunbo.JPADemo;import com.yangjunbo.JPADemo.pojo.Book;
import com.yangjunbo.JPADemo.repository.BookRepository;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;@RunWith(SpringRunner.class)
@SpringBootTest
public class TestSave {@Autowiredprivate BookRepository repository;@Testpublic void testSave() {Book book = new Book();book.setId((long) 1);book.setBookName("西游记");book.setAuthor("吴承恩");repository.save(book);Book newbook=repository.findById(1).orElse(null);System.out.println(newbook);}
}

在这里插入图片描述在这里插入图片描述结果表明索引数据保存成功,并且通过id能查询到保存的索引数据信息,说明在Spring Boot中成功集成Elasticsearch。

7.遇到的问题
当使用springboot和es版本不匹配就会报下面的错
Unable to parse response body for Response{requestLine=PUT /book/_doc/1?timeout=1m HTTP/1.1, host=http://127.0.0.1:9200, response=HTTP/1.1 201 Created}
springboot和elasticsearch的版本
如果启动7点几版本的es失败,提示jdk不清楚开发者,请注意下图的地方点击仍要打开。
在这里插入图片描述
参考书籍《springboot从入门到实战-章为忠著》

相关内容

热门资讯

上海知名拆迁律师机构推荐,诚信... 在上海,拆迁问题一直备受关注,选择一位靠谱的拆迁律师至关重要。知名的拆迁律师机构和诚信的拆迁专业律师...
老师诅咒全班得甲流 律师:违反... 大象新闻记者 姜明圆 “让他们全都甲流,赶紧滚回去。”近日,小学老师百人群内咒骂全班得甲流,引发网友...
甘其毛都司法所“中蒙桥”调解室... 近日,内蒙古巴彦淖尔市乌拉特中旗甘其毛都司法所以“一所一品”特色服务品牌创建为抓手,以“双语沟通、双...
沙坪坝区首家“社区法律诊所”开... “非独生子女家庭,把财产通过遗嘱方式全给儿子继承,违法吗?”“母亲的黄昏恋对象,需要我们来赡养吗?”...
桃源法院:柔性化解租赁合同纠纷... 近日,桃源县人民法院成功调解一起厂房租赁合同纠纷案件,既维护了原告桃源县某投资公司的合法权益,又为被...
重庆啤酒“山城往事”落幕,1亿... 蓝鲸新闻12月17日讯(记者 朱欣悦)重庆啤酒的“山城往事”终于要告一段落。 近日,重庆啤酒披露,与...
法治赋能促“绿叶”变“金叶”,... 12月16日,清远市人大常委会办公室举行《清远市促进英德红茶产业发展条例》颁布施行新闻发布会。据通报...
泽普县司法局开展矛盾纠纷化解暨... 12月15日,泽普县司法局在波斯喀木乡梧桐村,开展矛盾纠纷化解和法律援助宣讲活动。活动现场,工作人员...