0


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

文章目录

            ⭐️秋日的晚霞⭐️

        ⭐️玲珑骰子安红豆 入骨相思知不知⭐️

💋     如果对你有帮助,给博主一个免费的点赞  💋
👋     博客主页🎉   秋日的晚霞
⭐️     更多文章     请关注主页    📝
👋     一起走上java学习之路!
🎄     欢迎各位🔎点赞👍评论收藏⭐️     🎄

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

  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<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 - 参考文档


本文转载自: https://blog.csdn.net/JAVAlife2021/article/details/123487624
版权归原作者 秋日的晚霞 所有, 如有侵权,请联系我们删除。

“3分钟SpringData整合 ElasticSearch 实现CRUD超级详细”的评论:

还没有评论