springboot整合spring data elasticsearch

jpa的特性

jpa可以自定义接口查询,也就意味着自己在mappe按照要求写一个方法,service只需要调用传值就可以了

一,创建maven项目导入依赖

XML 复制代码
<parent>
    <artifactId>spring-boot-starter-parent</artifactId>
    <groupId>org.springframework.boot</groupId>
    <version>2.3.6.RELEASE</version>
</parent>
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
    </dependency>
</dependencies>

二,创建application.yml配置文件

XML 复制代码
spring:
  elasticsearch:
    rest:
      uris: http://localhost:9200

三,创建实体类

java 复制代码
@Data
@Document(indexName = "goods")
public class Goods implements Serializable {

    @Field(type = FieldType.Keyword)
    private String id;
    @Field(type = FieldType.Text)
    private String goodsName;
    @Field(type = FieldType.Integer)
    private Integer store;
    @Field(type =FieldType.Double)
    private double price;
}

四,创建dao层

java 复制代码
@Repository
public interface GoodsDao extends ElasticsearchRepository<Goods,String> {
}

五,创建主启动类

java 复制代码
@SpringBootApplication
public class ElasticsearchApplication {
    public static void main(String[] args) {
        SpringApplication.run(ElasticsearchApplication.class, args);
    }
}

六,注入测试

java 复制代码
@RunWith(SpringRunner.class)
@SpringBootTest(classes = ElasticsearchApplication.class)
public class ElastricsearchTest {

    //注入dao
    @Autowired
    private GoodsDao goodsDao;


    /**
    * @Description: 插入一个
    * @Author: Mr.Zhan
    * @Date: 2022/2/14
    */
       @Test
       public  void  testCreate(){
           Goods goods = new Goods("1","springoot整合",12,300.0);
           goodsDao.save(goods);

       }

       /**
       * @Description: 插入多个
       * @Author: Mr.Zhan
       * @Date: 2022/2/14
       */
          @Test
          public  void  testCerateMany(){
              ArrayList<Goods> list = new ArrayList<>();
              Goods goods = new Goods("2","springoot整合2",12,300.0);
              Goods goods1 = new Goods("3","springoot整合3",12,300.0);
              list.add(goods);
              list.add(goods1);
              goodsDao.saveAll(list);
          }
          /**
          * @Description: 根据id查询
          * @Author: Mr.Zhan
          * @Date: 2022/2/14
          */
             @Test
             public  void  testFindById(){
                 Optional<Goods> goods = goodsDao.findById("2");
                 System.out.println("goods.get() = " + goods.get());
             }

             /**
             * @Description: 根据所有查询
             * @Author: Mr.Zhan
             * @Date: 2022/2/14
             */
                @Test
                public  void  testFindAll(){
                    goodsDao.findAll().forEach((z)-> System.out.println("z = " + z));
                }


                /**
                * @Description: 修改
                * @Author: Mr.Zhan
                * @Date: 2022/2/14
                */
                   @Test
                   public  void  testUpdate(){
                       Goods goods = new Goods("3","springoot整合2",12,200.0);
                       goodsDao.save(goods);
                   }

                   /**
                   * @Description: 排序查询
                   * @Author: Mr.Zhan
                   * @Date: 2022/2/14
                   */
                      @Test
                      public  void  testSort(){
                          ArrayList<String>  list= new ArrayList<>();
                          list.add("price");
                          Sort orders = new Sort(Sort.Direction.ASC,list);
                          goodsDao.findAll(orders);
                      }

                      /**
                      * @Description: 分页查询
                      * @Author: Mr.Zhan
                      * @Date: 2022/2/14
                      */
                         @Test
                         public  void  testPageResult(){
                             Pageable pageable = Pageable.unpaged();
                             goodsDao.findAll(Pageable.unpaged()).get().forEach((s)-> System.out.println("s = " + s));
                         }
}
相关推荐
咚为3 小时前
Rust Print 终极指南:从底层原理到全场景实战
开发语言·后端·rust
二哈喇子!3 小时前
SpringBoot项目右上角选择ProjectNameApplication的配置
java·spring boot
二哈喇子!3 小时前
基于Spring Boot框架的车库停车管理系统的设计与实现
java·spring boot·后端·计算机毕业设计
二哈喇子!4 小时前
基于SpringBoot框架的水之森海底世界游玩系统
spring boot·旅游
二哈喇子!4 小时前
Java框架精品项目【用于个人学习】
java·spring boot·学习
二哈喇子!4 小时前
基于SpringBoot框架的网上购书系统的设计与实现
java·大数据·spring boot
二哈喇子!5 小时前
基于JavaSE的淘宝卖鞋后端管理系统的设计与实现
java·spring boot·spring
Coder_Boy_5 小时前
基于SpringAI的在线考试系统-智能考试系统-学习分析模块
java·开发语言·数据库·spring boot·ddd·tdd
高山上有一只小老虎6 小时前
mybatisplus实现分页查询
java·spring boot·mybatis
Loo国昌7 小时前
【LangChain1.0】第九阶段:文档处理工程 (LlamaIndex)
人工智能·后端·python·算法·langchain