java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > SpringData ElasticSearch实现CRUD

SpringData整合ElasticSearch实现CRUD的示例代码(超详细)

作者:秋日的晚霞

本文主要介绍了SpringData整合ElasticSearch实现CRUD的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

1.导入依赖

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
            <version>2.6.4</version>
        </dependency>

2.配置 yml

spring:
  elasticsearch:
    rest:
      uris:
        - http://xxxxx:9200

3.创建Bean

@Document(indexName = "goods" , shards = 3,replicas = 2)
public class Goods {
    // 商品Id skuId
    @Id
    private Long id;
    @Field(type = FieldType.Keyword, index = false)
    private String defaultImg;
    //  es 中能分词的字段,这个字段数据类型必须是 text!keyword 不分词!
    @Field(type = FieldType.Text, analyzer = "ik_max_word")
    private String title;
    @Field(type = FieldType.Double)
    private Double price;
    //  @Field(type = FieldType.Date)   6.8.1
    @Field(type = FieldType.Date,format = DateFormat.custom,pattern = "yyyy-MM-dd HH:mm:ss")
    private Date createTime; // 新品
    @Field(type = FieldType.Long)
    private Long tmId;
    @Field(type = FieldType.Keyword)
    private String tmName;
    @Field(type = FieldType.Keyword)
    private String tmLogoUrl;
    @Field(type = FieldType.Long)
    private Long category1Id;
    @Field(type = FieldType.Keyword)
    private String category1Name;
    @Field(type = FieldType.Long)
    private Long category2Id;
    @Field(type = FieldType.Keyword)
    private String category2Name;
    @Field(type = FieldType.Long)
    private Long category3Id;
    @Field(type = FieldType.Keyword)
    private String category3Name;
    //  商品的热度! 我们将商品被用户点查看的次数越多,则说明热度就越高!
    @Field(type = FieldType.Long)
    private Long hotScore = 0L;
    // 平台属性集合对象
    // Nested 支持嵌套查询
    @Field(type = FieldType.Nested)
    private List<SearchAttr> attrs;
}

4.创建接口继承 CrudRepository 接口

泛型1 : ES对应的javaBean

泛型2 : 文档唯一ID的类型

@Repository
public interface GoodsDao extends CrudRepository<Goods,Long> {
}

注意 如果想实现分页 请实现 PagingAndSortingRepository 接口

@Repository
public interface GoodsDao extends PagingAndSortingRepository<Goods,Long> {
}

接口上添加 @Repository 注解

image-20220314200112925

5. 创建service 注入 接口代理类对象

@Service
public class GoodsServiceImpl implements GoodService {
    @Autowired
    private GoodsDao goodsDao;
    @Override
    public boolean onSale(Goods goods) {
        Goods save = goodsDao.save(goods);
       return !StringUtils.isEmpty(save);
    }
}

6.主启动类上添加 @EnableElasticsearchRepositories

@EnableElasticsearchRepositories
@SpringCloudApplication
public class EsListApp {
    public static void main(String[] args) {
        SpringApplication.run(EsListApp.class);
    }
}

7.编写方法名

小提示 先写返回值类型 这样有提示

idea64_vJZvPkhh48

命名规则 Spring Data Commons - 参考文档

到此这篇关于SpringData整合ElasticSearch实现CRUD的示例代码(超详细)的文章就介绍到这了,更多相关SpringData ElasticSearch实现CRUD内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文