列存在查询(ExistQuery),也叫NULL查询或者空值查询。一般用于稀疏数据中,判断某一行的某一列是否存在,例如查询所有数据中,address列不为空的行有哪些。

说明 如果需要查询某一列为空,则需要和bool query中的must_not语句结合。

参数

fieldName:列名。

示例

/**
 * 使用列存在查询,查询表中address这一列的不为空的数据
 * @param client
 */
private static void existQuery(SyncClient client) {
    SearchQuery searchQuery = new SearchQuery();
    ExistsQuery existQuery = new ExistsQuery(); // 设置查询类型为ExistsQuery
    existQuery.setFieldName("address");
    searchQuery.setQuery(existQuery);
    SearchRequest searchRequest = new SearchRequest(TABLE_NAME, INDEX_NAME, searchQuery);

    SearchRequest.ColumnsToGet columnsToGet = new SearchRequest.ColumnsToGet();
    columnsToGet.setReturnAll(true); // 设置返回所有列
    searchRequest.setColumnsToGet(columnsToGet);

    SearchResponse resp = client.search(searchRequest);

    System.out.println("TotalCount: " + resp.getTotalCount()); // 匹配到的总行数,非返回行数
    System.out.println("Row: " + resp.getRows());
}