3分钟SpringData整合 ElasticSearch 实现CRUD超级详细

1.导入依赖

		
            org.springframework.boot
            spring-boot-starter-data-elasticsearch
            2.6.4
        

2.配置 yml

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

3.创建Bean

  1. @Document( indexName= xxx) ES 的索引名
  2. @Id ES 的文档ID
  3. @Field ES的字段映射
  4. type = FieldType.Keyword 关键字 不分词 ( ES中没有String 只有 text (分词) 和 keyword ( 不分词 )
  5. index 是否能索引
  6. analyzer 使用的分词器
  7. format 格式转换 pattern 日期格式
  8. FieldType.Nested 集合属性 避免查出业务错误
@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 attrs;

}

4.创建接口继承 CrudRepository 接口

泛型1 : ES对应的javaBean

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

@Repository
public interface GoodsDao extends CrudRepository {


}

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

@Repository
public interface GoodsDao extends PagingAndSortingRepository {


}

接口上添加 @Repository 注解

3分钟SpringData整合 ElasticSearch 实现CRUD超级详细_第1张图片

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.编写方法名

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

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

你可能感兴趣的:(ElasticSearch,elasticsearch,搜索引擎,java)