ElasticSearch 6.2.2 學(xué)習(xí)筆記(4) Java API 之 SpringBoot中的使用 2019-04-06

一、實體(Entity)

@Document(indexName = "my_index", type = "newsEntity",shards = 1, replicas = 0, refreshInterval = "-1")

//Document :每一條記錄就是一篇文檔

//indexName :文檔的索引名稱--唯一標(biāo)記

//type :文檔類型 doc ppt xls story product

//shards : 數(shù)據(jù)分片個數(shù) 默認(rèn)將數(shù)據(jù)存6份,5個主份+1個備份

public class NewsEntityextends BaseModel {

//編號id 主鍵

? ??@Id

? ? String id;

//type : Text表示文本,可被分詞也可被索引;Keyword表示關(guān)鍵字,不分詞可被索引,但String被分詞

//index : true表示可被索引;false表示不可被索引

//store : true表示可被儲存;alse表示不可被儲存

//analyzer : 執(zhí)行分詞器

? ? @Field(type = FieldType.Text, analyzer ="ik_max_word")

Stringtitle;

? ? @Field(type = FieldType.Text, analyzer ="ik_max_word")

Stringcontent;


二、源碼解釋

(1)@Document

@Persistent

@Inherited

@Retention(RetentionPolicy.RUNTIME)

@Target({ElementType.TYPE})

public @interface Document {

StringindexName(); //索引名稱

? ? Stringtype()default "";//文檔類型

? ? boolean useServerConfiguration()default false;//是否使用服務(wù)配置

? ? short shards()default 5;//默認(rèn)分區(qū)數(shù)

? ? short replicas()default 1;//每個分區(qū)的默認(rèn)備份數(shù)

? ? StringrefreshInterval()default "1s";//刷新間隔

? ? StringindexStoreType()default "fs";//索引文件存儲類型

? ? boolean createIndex()default true;//是否創(chuàng)建索引

}

(2)@Field

@Retention(RetentionPolicy.RUNTIME)

@Target({ElementType.FIELD})

@Documented

@Inherited

public @interface Field {

FieldTypetype()default FieldType.Auto;//自動檢測屬性的類型

? ? boolean index()default true;//是否創(chuàng)建屬性的索引

? ? DateFormatformat()default DateFormat.none;//日期格式

? ? Stringpattern()default "";//驗證的正則表達式

? ? boolean store()default false;//是否存儲

? ? boolean fielddata()default false;//是否延遲加載

? ? StringsearchAnalyzer()default "";//執(zhí)行字段搜索時使用的分詞器

? ? Stringanalyzer()default "";//存儲字段時指定分詞器

? ? Stringnormalizer()default "";//'lowercast'做小寫變換

? ? String[]ignoreFields()default {};//如果某個字段需要被忽略時加入

? ? boolean includeInParent()default false;//是否解析

? ? String[]copyTo()default {};

}


三、索引的基本使用

@Resource

private ElasticsearchTemplateelasticsearchTemplate;

@Resource

private NewsRepositoryrepository;

//創(chuàng)建文檔索引

@Test

public void creationIndex() {elasticsearchTemplate.createIndex(NewsEntity.class); }

//設(shè)置映射關(guān)系(把文檔類中的屬性結(jié)構(gòu)和Elasticsearch內(nèi)部結(jié)構(gòu)對應(yīng))

@Test

public void creationMapping() {elasticsearchTemplate.putMapping(NewsEntity.class); }

//刪除索引

@Test

public void deleteIndex() {elasticsearchTemplate.deleteIndex(NewsEntity.class); }


四、文檔操作

@Resource

private NewsRepositoryrepository;

NewsEntitynewsEntity =new NewsEntity();

//添加

@Test

private void saveDocument(NewsEntity newsEntity) {repository.save(newsEntity); }

//刪除

@Test

private void deleteDocument(NewsEntity newsEntity) {repository.delete(newsEntity);}

//批量添加

@Test

public void saveDocuments(List<NewsEntity> newsEntities) {repository.saveAll(newsEntities); }

//更新

//elasticsearch和Lucene一樣沒有提供更新方法,想要更新就需要重新添加,但必須保持文檔主鍵一致

@Test

public void updateDocument(NewsEntity newsEntity) {repository.save(newsEntity);}

//分頁查詢


@Test

public void pageSearch() {

//第一個參數(shù)是分頁數(shù),從零開始計數(shù)表示第一頁

? ? //第二個參數(shù)是分頁的條目數(shù)

? ? Page<NewsEntity> newsEntityPage =repository.findAll(PageRequest.of(0, 2));

}

//按字段排序查詢

@Test

public void sort() {

//查詢所有的里面指定排序的字段,并可以繼續(xù)調(diào)用排序方式(升ascending降descending),默認(rèn)降序

? ? Iterable<NewsEntity> newsEntities =repository.findAll(Sort.by("sort").descending());

}



Dao自定義查詢方法

Dao類:

@Component

public interface NewsRepositoryextends ElasticsearchRepository {

/**

? ? * 根據(jù)標(biāo)題查詢

? ? * @param title

? ? * @return

? ? */

? public List<NewsEntity>?findByTitle(String title);

? ? /**

? ? * 根據(jù)兩個數(shù)字區(qū)間查詢

? ? * @param addtime1

? ? * @param addtime2

? ? * @return

? ? */

? public List<NewsEntity>?findByAddtime(Integer addtime1,Integer addtime2);

}



//詞條查詢

@Test

public void termSearch() { List entities =repository.findByTitle("獎學(xué)金"); }

//范圍查詢

@Test

public void addTimeSearch() { List entities =repository.findByAddtime(0,120315356); }



//自定義查詢(自己構(gòu)造查詢條件,對比基礎(chǔ)查詢,搜索內(nèi)容有了條件)

? ? @Test

? ? public void termSearch1() {

//創(chuàng)建查詢條件生成器

? ? ? ? NativeSearchQueryBuilder nativeSearchQueryBuilder =new NativeSearchQueryBuilder();

? ? ? ? nativeSearchQueryBuilder.withQuery(QueryBuilders.termQuery("title","獎學(xué)金"));

? ? ? ? //查詢到的結(jié)果,自動分頁,默認(rèn)第一頁,每頁條目數(shù)是10條(itemRepository相當(dāng)于文檔讀取器,參數(shù)中的文檔查詢對象需要構(gòu)建下)

? ? ? ? //在查詢條件生成器中生成查詢對象所以去build構(gòu)建

????????//Pageable pageable = new PageRequest(1,10);

????????//nativeSearchQueryBuilder.withPageable(pageable);

? ? ? ? Page entityPage =repository.search(nativeSearchQueryBuilder.build());

? ? }


//match匹配查詢

@Test

public void matchSearch() {

NativeSearchQueryBuilder nativeSearchQueryBuilder =new NativeSearchQueryBuilder();

? ? nativeSearchQueryBuilder.withQuery(QueryBuilders.matchQuery("title","獎學(xué)金"));

? ? Page<NewsEntity>?newsEntityPage =repository.search(nativeSearchQueryBuilder.build());

}


//布爾查詢(綜合查詢)

@Test

public void boolenSearch() {

NativeSearchQueryBuilder nativeSearchQueryBuilder =new NativeSearchQueryBuilder();

? ? nativeSearchQueryBuilder.withQuery(QueryBuilders.boolQuery()

.must(QueryBuilders.matchQuery("title","獎學(xué)金"))

.must(QueryBuilders.matchQuery("source","Qq")));

? ? Page<NewsEntity> newsEntityPage =repository.search(nativeSearchQueryBuilder.build());

}


//容錯查詢(最多錯兩個)

@Test

public void fuzzSearch() {

NativeSearchQueryBuilder nativeSearchQueryBuilder =new NativeSearchQueryBuilder();

? ? nativeSearchQueryBuilder.withQuery(QueryBuilders.fuzzyQuery("title","獎學(xué)金"));

? ? Page newsEntityPage =repository.search(nativeSearchQueryBuilder.build());

? ? System.out.println();

}


//模糊查詢

//? 表示詢問一個未知的占位符,* 表示詢問0到n個任意占位符

@Test

public void wildCardSearch() {

NativeSearchQueryBuilder nativeSearchQueryBuilder =new NativeSearchQueryBuilder();

? ? nativeSearchQueryBuilder.withQuery(QueryBuilders.wildcardQuery("title","*獎*"));

? ? Page newsEntityPage =repository.search(nativeSearchQueryBuilder.build());

}


//分頁查詢

@Test

public void pageSearch() {

NativeSearchQueryBuilder nativeSearchQueryBuilder =new NativeSearchQueryBuilder();

? ? nativeSearchQueryBuilder.withQuery(QueryBuilders.wildcardQuery("title","*獎*"));

? ? //構(gòu)建分頁

? ? nativeSearchQueryBuilder.withPageable(PageRequest.of(1,10));

? ? Page newsEntityPage =repository.search(nativeSearchQueryBuilder.build());

}


//排序查詢

@Test

public void sortSearch() {

NativeSearchQueryBuilder nativeSearchQueryBuilder =new NativeSearchQueryBuilder();

? ? nativeSearchQueryBuilder.withQuery(QueryBuilders.wildcardQuery("title","*獎*"));

? ? //構(gòu)建排序

? ? nativeSearchQueryBuilder.withSort(SortBuilders.fieldSort("addtime").order(SortOrder.DESC));

? ? Page newsEntityPage =repository.search(nativeSearchQueryBuilder.build());

}


以上可以進行組合查詢,只要不違反規(guī)則便可以累加


聚合查詢

//包含子聚合的聚合查詢

@Test

public void aggregationSearch() {

NativeSearchQueryBuilder nativeSearchQueryBuilder =new NativeSearchQueryBuilder();

? ? nativeSearchQueryBuilder.addAggregation(AggregationBuilders.terms("sources").field("source"));

? ? //查詢

? ? AggregatedPage aggregatedPage = (AggregatedPage)repository.search(nativeSearchQueryBuilder.build());

? ? //根據(jù)聚合名稱獲取對應(yīng)的聚合

? ? StringTerms sources = (StringTerms) aggregatedPage.getAggregation("sources");

? ? //獲取查詢到的桶

? ? List buckets = sources.getBuckets();

? ? for (StringTerms.Bucket b : buckets) {

System.out.println("來源:"+b.getKeyAsString()+"文檔數(shù):"+b.getDocCount());

? ? }

}



最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,117評論 6 537
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,860評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,128評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,291評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 72,025評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,421評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,477評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,642評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,177評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,970評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,157評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,717評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,410評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,821評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,053評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,896評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 48,157評論 2 375

推薦閱讀更多精彩內(nèi)容