溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

spring-data-elasticsearch @Field注解無效怎么辦

發(fā)布時間:2021-07-27 13:49:15 來源:億速云 閱讀:463 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹了spring-data-elasticsearch @Field注解無效怎么辦,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

一. 準備實例代碼

這是實體類代碼,及其注解

package com.gupao.springbootdemo.bean; 
import lombok.Data;
import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;
import org.springframework.data.elasticsearch.annotations.Field;
import org.springframework.data.elasticsearch.annotations.FieldType; 
import java.util.List;
 
/**
 * 功能描述:ES的用戶
 *
 * @Author: zhouzhou
 * @Date: 2020/7/30$ 9:57$
 */
@Data
@Document(indexName = "es_user")
public class ESUser {
 
    @Id
    private Long id;
    @Field(type = FieldType.Text)
    private String name;
    @Field(type = FieldType.Integer)
    private Integer age;
    @Field(type = FieldType.Keyword)
    private List<String> tags;
    @Field(type = FieldType.Text, analyzer = "ik_max_word")
    private String desc;  
}

這是創(chuàng)建索引的代碼

boolean index = elasticsearchRestTemplate.createIndex(ESUser.class);

我們會發(fā)現(xiàn),當執(zhí)行后, 雖然執(zhí)行成功, 但是我們?nèi)ゲ榭此饕畔⒌臅r候發(fā)現(xiàn)沒有mapping信息

二. 解決方案

1.在createIndex方法后加putMapping方法

boolean index = elasticsearchRestTemplate.createIndex(ESUser.class);
elasticsearchRestTemplate.putMapping(ESUser.class);

問題解決,查看mapping信息就有了

spring-data-elasticsearch @Field注解無效怎么辦

2.更新版本(注: 版本更新對應要更新es版本到7.8以上,不建議!!)

spring-data-elasticsearch @Field注解無效怎么辦

項目啟動的時候,自動創(chuàng)建索引,無需手動調(diào)用API創(chuàng)建!!!

三. 解決思路(源碼部分,以下只是筆者解決過程)

筆者通過查看elasticsearcRestTemplate的源碼才發(fā)現(xiàn)

@Override
	public ElasticsearchPersistentEntity getPersistentEntityFor(Class clazz) {
		Assert.isTrue(clazz.isAnnotationPresent(Document.class), "Unable to identify index name. " + clazz.getSimpleName()
				+ " is not a Document. Make sure the document class is annotated with @Document(indexName=\"foo\")");
		return elasticsearchConverter.getMappingContext().getRequiredPersistentEntity(clazz);
	}

創(chuàng)建索引前會通過getMappingContext方法獲取mappingContext字段, 但是這個字段怎么賦值呢?

沒有頭緒!!!!!

筆者又轉(zhuǎn)念一想, 我們直接思考下, 我們找到@Field字段在哪里被解析, 這不就知道讀取@Field的類和設置mappingContext的方法了!!!!

妙 啊!!!!!!

spring-data-elasticsearch @Field注解無效怎么辦

原來是

MappingBuilder這個類對@Field進行解析, 后來進去發(fā)現(xiàn)@Mapping解析.json,也就是網(wǎng)上的方法解析方法也在里面, 哈哈殊途同歸, 對外提供的方法為:

spring-data-elasticsearch @Field注解無效怎么辦

看注釋, 我就知道離真相不遠了,繼續(xù)查看調(diào)用鏈, 真相大白!!!下面方法我就不多做解釋了

spring-data-elasticsearch @Field注解無效怎么辦

spring-data-elasticsearch @Field注解無效怎么辦

感謝你能夠認真閱讀完這篇文章,希望小編分享的“spring-data-elasticsearch @Field注解無效怎么辦”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI