1、ES文檔中keyword意思是:字符串,但不需要分詞
2、ES細節CreateIndexRequest request = new CreateIndexRequest("items");會讓你導包,會有兩個選擇:
????????import org.elasticsearch.action.admin.indices.create.CreateIndexRequest;
????????import org.elasticsearch.client.indices.CreateIndexRequest;
一般選擇帶client的那個,因為這個用于ES7之后的。而我們IDEA使用的是ES7.12.1
3、ES中文檔:document;? ? ?庫:index
4、下面這個是多個文檔(document),而不是一個文檔。它們可以存在一個庫里。
{"id": 1,"title": "小米手機","price": 3499
}
{"id": 2,"title": "華為手機","price": 4999
}
{"id": 3,"title": "華為小米充電器","price": 49
}
{"id": 4,"title": "小米手環","price": 299
}
?5、不光mapper層可以查詢等操作,MP自帶的Iservice也可以。
@Test
void testLoadItemDocs() throws IOException {// 分頁查詢商品數據int pageNo = 1;int size = 1000;while (true) {Page<Item> page = itemService.lambdaQuery().eq(Item::getStatus, 1).page(new Page<Item>(pageNo, size));// 非空校驗List<Item> items = page.getRecords();if (CollUtils.isEmpty(items)) {return;}log.info("加載第{}頁數據,共{}條", pageNo, items.size());// 1.創建RequestBulkRequest request = new BulkRequest("items");// 2.準備參數,添加多個新增的Requestfor (Item item : items) {// 2.1.轉換為文檔類型ItemDTOItemDoc itemDoc = BeanUtil.copyProperties(item, ItemDoc.class);// 2.2.創建新增文檔的Request對象request.add(new IndexRequest().id(itemDoc.getId()).source(JSONUtil.toJsonStr(itemDoc), XContentType.JSON));}// 3.發送請求client.bulk(request, RequestOptions.DEFAULT);// 翻頁pageNo++;}
}
Page<Item> page = itemService.lambdaQuery().eq(Item::getStatus, 1).page(new Page<Item>(pageNo, size));這個lambdaQuery是ItemService繼承了Iservice然后Iservice中寫了lambdaQuery這個在service層就可以查詢的方法。
6、ES的DSL查詢分為葉子查詢和復合查詢
7、看到這個算法公式的時候,我很慶幸自己學的是計算機而不是數學😭。
? ? ? I Love Computer Since!
我愛計算機💗
8、下面這個RestClient查詢指的是在IDEA中調用API
??9、底層源碼分析:
? ? ? ? 我們說“大類+點”只能調用方法,不能調用變量,為什么下面這個總感覺有問題。
底層原理是類可以“返回類本身(其實不是類,而是對象)”。并且這個大類通過連續調用自己,最終只返回了一個對象,且只返回了一個對象,也不是返回的類!這點很重要!因此為什么要獲取這個類的時候我們要用"大類.Class"
下面這個類調用的不是方法,返回的也不是類本身的對象。這個類調用的是靜態的一個變量。
10、復合查詢是:包含多個葉子查詢
11、下面這個什么意思?是只繼承了這個Ixxx接口的唯一一個接口Rxxx
12、這個類是干了個啥事?
?它的底層代碼是這樣的:
這里的String...意思是可以傳入0個、1個或多個字符串。這里如果傳入多個字符串的話,這些字符串最終構成了一個String[]數組。并且創建一個SearchSoueceBuilder()? ?防御性編程。保證每個?SearchRequest
?對象被創建后,始終有一個可用的?SearchSourceBuilder
,避免后續調用?request.source()
?時出現?NullPointerException
13、很重要的代碼:? ?斜杠后面的話很重要//
@Testvoid testBool() throws IOException {// 1.創建Request,是為了最后執行這個requestSearchRequest request = new SearchRequest("items");BoolQueryBuilder bool = QueryBuilders.boolQuery();bool.must(QueryBuilders.matchQuery("name", "脫脂牛奶"));bool.filter(QueryBuilders.termQuery("brand", "德亞"));bool.filter(QueryBuilders.rangeQuery("price").lte(30000));//把price、30000分別通過rangeQuery、lte這兩個方法賦值給了一個QueryBuilders對象,然后又通過BoolQueryBuilder的must方法、filter方法傳入了一個只裝QueryBuilders的List集合!很重要是集合!request.source().query(bool);//這個source沒有傳入值,query傳入了bool這個值,兩個方法同時調用,所以最終返回的一定是個對象,而沒有查詢。SearchResponse response = client.search(request, RequestOptions.DEFAULT);//構建了一個SearchResponse對象handleResponse(response);//handleResponse執行了response這個對象,實現了搜索。}