Timeline管理提供了訊息模糊查詢、多條件組合查詢介面。
Timeline管理的查詢功能基於多元索引,只有設定了IndexSchema的TimelineStore才支援。索引類型支援LONG、DOUBLE、BOOLEAN、KEYWORD、GEO_POINT、TEXT等類型,屬性包含Index、Store、Array以及分詞器,其含義與多元索引相同。更多資訊,請參見資料類型映射。
Search
多維度組合查詢,需要模糊查詢的欄位,按照需求建立TEXT類型,並設定需要的分詞器。
/**
* Search timeline by SearchParameter.
* */
SearchParameter searchParameter = new SearchParameter(
field("text").equals("fieldValue")
);
timelineStore.search(searchParameter);
/**
* Search timeline by SearchQuery.
* */
TermQuery query = new TermQuery();
query.setFieldName("text");
query.setTerm(ColumnValue.fromString("fieldValue"));
SearchQuery searchQuery = new SearchQuery().setQuery(query).setLimit(10);
timelineStore.search(searchQuery);
Flush
批量寫基於Tablestore SDK中DefaultTableStoreWriter實現,可以主動調用flush介面,將Buffer中尚未發出的請求主動觸發發送,同步等待至所有訊息寫入成功。
/**
* Flush messages in buffer, and wait until all messages are stored.
* */
timelineStore.flush();