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

一宝鼓、實體(Entity)

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

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

//indexName :文檔的索引名稱--唯一標記

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

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

public class NewsEntityextends BaseModel {

//編號id 主鍵

? ??@Id

? ? String id;

//type : Text表示文本,可被分詞也可被索引;Keyword表示關鍵字,不分詞可被索引,但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;//是否使用服務配置

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

? ? short replicas()default 1;//每個分區(qū)的默認備份數(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); }

//設置映射關系(把文檔類中的屬性結構和Elasticsearch內部結構對應)

@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ù)調用排序方式(升ascending降descending),默認降序

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

}



Dao自定義查詢方法

Dao類:

@Component

public interface NewsRepositoryextends ElasticsearchRepository {

/**

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

? ? * @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("獎學金"); }

//范圍查詢

@Test

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



//自定義查詢(自己構造查詢條件佑力,對比基礎查詢,搜索內容有了條件)

? ? @Test

? ? public void termSearch1() {

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

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

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

? ? ? ? //查詢到的結果植袍,自動分頁伪很,默認第一頁,每頁條目數(shù)是10條(itemRepository相當于文檔讀取器奋单,參數(shù)中的文檔查詢對象需要構建下)

? ? ? ? //在查詢條件生成器中生成查詢對象所以去build構建

????????//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","獎學金"));

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

}


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

@Test

public void boolenSearch() {

NativeSearchQueryBuilder nativeSearchQueryBuilder =new NativeSearchQueryBuilder();

? ? nativeSearchQueryBuilder.withQuery(QueryBuilders.boolQuery()

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

.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","獎學金"));

? ? 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","*獎*"));

? ? //構建分頁

? ? 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","*獎*"));

? ? //構建排序

? ? 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ù)聚合名稱獲取對應的聚合

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

? ? //獲取查詢到的桶

? ? List buckets = sources.getBuckets();

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

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

? ? }

}



最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末览濒,一起剝皮案震驚了整個濱河市呆盖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌贷笛,老刑警劉巖应又,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異乏苦,居然都是意外死亡株扛,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門汇荐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來洞就,“玉大人,你說我怎么就攤上這事掀淘⊙” “怎么了?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵革娄,是天一觀的道長倾贰。 經常有香客問我,道長拦惋,這世上最難降的妖魔是什么匆浙? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮厕妖,結果婚禮上首尼,老公的妹妹穿的比我還像新娘。我一直安慰自己叹放,他們只是感情好饰恕,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布挠羔。 她就那樣靜靜地躺著井仰,像睡著了一般。 火紅的嫁衣襯著肌膚如雪破加。 梳的紋絲不亂的頭發(fā)上俱恶,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天,我揣著相機與錄音,去河邊找鬼合是。 笑死了罪,一個胖子當著我的面吹牛,可吹牛的內容都是我干的聪全。 我是一名探鬼主播泊藕,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼难礼!你這毒婦竟也來了娃圆?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤蛾茉,失蹤者是張志新(化名)和其女友劉穎讼呢,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體谦炬,經...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡悦屏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了键思。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片础爬。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖吼鳞,靈堂內的尸體忽然破棺而出幕帆,到底是詐尸還是另有隱情,我是刑警寧澤赖条,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布失乾,位于F島的核電站,受9級特大地震影響纬乍,放射性物質發(fā)生泄漏碱茁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一仿贬、第九天 我趴在偏房一處隱蔽的房頂上張望纽竣。 院中可真熱鬧,春花似錦茧泪、人聲如沸蜓氨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽穴吹。三九已至,卻和暖如春嗜侮,著一層夾襖步出監(jiān)牢的瞬間港令,已是汗流浹背啥容。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留顷霹,地道東北人咪惠。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像淋淀,于是被迫代替她去往敵國和親遥昧。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內容