Springboot intègre elasticsearch pour réaliser des ajouts, suppressions et modifications simples

Prémisse: Tout d'abord, bien sûr, l'environnement es est configuré, vous pouvez vous référer à mon blog précédent https://blog.csdn.net/weixin_39025362/article/details/105359306

1. Créer un projet springboot et introduire la dépendance maven de es et lombok

<dependency>
   <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>
<!--lombok是创建实体类通过注解@Data为实体创建get、set、toString等方法,使我们的实体类非常简洁-->
 <dependency>
   <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
</dependency>

2. Créer une bibliothèque d'index es

1. La bibliothèque d'index peut être créée via le plug-in postman ou head. L'auteur utilise es6.2.4 L'
introduction suivante utilise postman pour créer la bibliothèque d'index es, put request, url: http: // localhost: 9200 / test-search
comme décrit dans mysql , Consiste à créer une base de données appelée test-search, puis une table de données appelée article,
avec trois champs, id long type, title text type using ik word search, content text type, using ik word search

{
  "settings": {
    "index.number_of_shards": 1,
    "index.number_of_replicas": 0,
    "index.refresh_interval": "-1"
  },
  "mappings": {
    "article": {
      "properties": {
        "id": {
          "type": "long",
          "index": false
        },
        "title": {
          "type": "text",
          "analyzer": "ik_max_word",
          "search_analyzer": "ik_max_word"
        },
        "content": {
          "type": "text",
          "analyzer": "ik_max_word",
          "search_analyzer": "ik_max_word",
          "boost": 1.5
        }
      }
    }
  }
}

Insérez la description de l'image ici
Bibliothèque d'index créée avec succès
Insérez la description de l'image ici

3. Revenez au projet springboot et commencez à écrire du code

1. Créez une classe d'entité appelée article

@Data
@Document(indexName = "test-search",type = "article",shards = 1,replicas = 0, refreshInterval = "-1")
public class Article implements Serializable {
    private Long id;

    private String title; //标题

    private String content;// 缩略内容
    
}

Couche 2.dao, créer une interface ArticleRepository, héritant ElasticsearchRepository

public interface ArticleRepository extends ElasticsearchRepository<Article,Long> {
    /**
     * 使用jpa的一个好处就是你想联合title和content去搜索,它就会有方法出现,使用pageable分页
     * @param title
     * @param content
     * @param pageable
     * @return
     */
    Page<Article> findByTitleLikeOrContentLike(String title, String content, Pageable pageable);

    /**
     * 根据article的content内容去搜索,使用pageable份额有
     * @param content
     * @param pageable
     * @return
     */
    Page<Article> findByContentLike(String content, Pageable pageable);
}

3. couche de service,

@Service
public class ArticleService {
    @Autowired
    private ArticleRepository articleRepository;

    public void save(Article article){
        articleRepository.save(article);
    }

    public Page<Article> search(String title, String content, Pageable pageable){
        return articleRepository.findByTitleLikeOrContentLike(title,content,pageable);
    }

    public Page<Article> search(String content,Pageable pageable){
        return articleRepository.findByContentLike(content,pageable);
    }
    public Page<Article> findAll(Pageable pageable){
        return articleRepository.findAll(pageable);
    }
}

Contrôleur 4 ,


@RestController
public class ArticleController {
    @Autowired
    private ArticleRepository articleRepository;

    @Autowired
    private ArticleService articleService;
	
	//可以插入单条也可以多条
    @RequestMapping("/articleSave")
    public String save(){
    List<Article> articles = new ArrayList<>();
    articles.add(new Article(System.currentTimeMillis(),"小米",
            "小米手机"));
    articles.add(new Article(System.currentTimeMillis(),"华为",
            "华为手机"));

    for(int i=0; i<articles.size(); i++){
        articleRepository.save(articles.get(i));
        System.out.println(articles.get(i));
    }
    return "success";
    }

    @RequestMapping("/search")
    public String search(HttpServletRequest request){
        int pageNum = 0;
        int pageSize = 10;
        String title = request.getParameter("title");
        String content = request.getParameter("content");
        Pageable pageable = PageRequest.of(pageNum,pageSize);
        Page<Article> articles = articleService.search(title,content,pageable);
        return articles.toString();
    }
}

Publié 25 articles originaux · loué 4 · visites 1516

Je suppose que tu aimes

Origine blog.csdn.net/weixin_39025362/article/details/105360676
conseillé
Classement