嵌套类型查询

更新时间:
复制为 MD 格式

NestedQuery用于查询嵌套类型字段中子行的数据。嵌套类型不能直接查询,需要通过NestedQuery包装,NestedQuery中需要指定嵌套类型字段的路径和一个子查询,其中子查询可以是任意Query类型。

前提条件

参数

参数

说明

tableName

数据表名称。

indexName

多元索引名称。

path

嵌套字段的路径。例如,news.title 表示嵌套字段 news 中的子字段 title

query

针对嵌套字段子列的查询条件,支持任意查询类型。

scoreMode

当字段存在多个值时,用于计算相关性得分的模式。

InnerHits

嵌套字段子列的配置参数,包含以下配置项:

  • sort:嵌套子行返回时的排序规则。

  • offset:当嵌套字段包含多个子行时,子行返回的起始位置。

  • limit:当嵌套字段包含多个子行时,返回子行的数量上限。默认值为 3。

  • highlight:嵌套子列的高亮参数配置。详细参数说明请参见摘要与高亮

示例

单层级嵌套类型查询示例

以下示例查询 Col_Nested.Sub_Col_Keyword 值为"开心"的数据行。Col_Nested 为嵌套类型字段,其子行包含 Sub_Col_Keyword 子列。

/**
 * Col_Nested 嵌套数据示例:'[{Sub_Col_Keyword: "开心"},{Sub_Col_Keyword: "晴天"}]'
 */
client.search({
    tableName: "<TABLE_NAME>",
    indexName: "<SEARCH_INDEX_NAME>",
    searchQuery: {
        offset: 0,
        limit: 10, // 仅需获取总行数时,可将 limit 设为 0,不返回任何数据行。
        query: { // 将查询类型设置为 TableStore.QueryType.NESTED_QUERY。
            queryType: TableStore.QueryType.NESTED_QUERY,
            query: {
                path: "Col_Nested",
                query: {
                    queryType: TableStore.QueryType.TERM_QUERY,
                    query: {
                        fieldName: "Col_Nested.Sub_Col_Keyword",
                        term: "开心"
                    }
                },
            }
        },
        getTotalCount: true // 返回结果中的 TotalCount 表示表中数据的总行数,默认为 false(不返回)。
    },
    columnToGet: { // 返回列设置:RETURN_SPECIFIED(自定义列)、RETURN_ALL(所有列)、RETURN_ALL_FROM_INDEX(多元索引中的所有列)、RETURN_NONE(不返回列)。
        returnType: TableStore.ColumnReturnType.RETURN_ALL
    }
}, function (err, data) {
    if (err) {
        console.log('error:', err);
        return;
    }
    console.log('success:', JSON.stringify(data, null, 2));
});

嵌套类型查询使用查询摘要与高亮示例

以下示例使用 NestedQuery 查询 Col_Nested 嵌套字段中 Sub_Col_Text 子列值能够匹配tablestore的数据行,并对返回结果中的匹配词进行高亮显示。

client.search({
    tableName: "<TABLE_NAME>",
    indexName: "<SEARCH_INDEX_NAME>",
    searchQuery: {
        offset: 0,
        limit: 10, // 仅需获取总行数时,可将 limit 设为 0,不返回任何数据行。
        query: { // 将查询类型设置为 TableStore.QueryType.NESTED_QUERY。
            queryType: TableStore.QueryType.NESTED_QUERY,
            query: {
                path: "Col_Nested",
                query: {
                    queryType: TableStore.QueryType.MATCH_QUERY,
                    query: {
                        fieldName: "Col_Nested.Sub_Col_Text",
                        text: "tablestore"
                    }
                },
                innerHits: {
                    sort: {
                        sorters: [
                            {
                                scoreSort: {
                                    order: TableStore.SortOrder.SORT_ORDER_DESC
                                }
                            },
                            {
                                docSort: {
                                    order: TableStore.SortOrder.SORT_ORDER_ASC
                                }
                            },
                        ],
                    },
                    highlight: {
                        highlightParameters: [
                            {
                                fieldName:"Col_Nested.Sub_Col_Text",
                                preTag: "<b>",
                                postTag: "</b>",
                                fragmentsOrder: TableStore.HighlightFragmentOrder.TEXT_SEQUENCE,
                                fragmentSize: 20,
                                numberOfFragments: 3,
                            }
                        ]
                    }
                },
            }
        },
        getTotalCount: true // 返回结果中的 TotalCount 表示表中数据的总行数,默认为 false(不返回)。
    },
    columnToGet: { // 返回列设置:RETURN_SPECIFIED(自定义列)、RETURN_ALL(所有列)、RETURN_ALL_FROM_INDEX(多元索引中的所有列)、RETURN_NONE(不返回列)。
        returnType: TableStore.ColumnReturnType.RETURN_ALL
    }
}, function (err, data) {
    if (err) {
        console.log('error:', err);
        return;
    }
    console.log('success:', JSON.stringify(data.rows, null, 2));

    printSearchHit(data.searchHits, "");
});

/**
 * 打印 searchHit 内容。
 * @param searchHits searchHits 结果集
 * @param prefix 嵌套结构输出时,通过前缀标识层级信息。
 */
function printSearchHit(searchHits, prefix) {
    TableStore.util.arrayEach(searchHits, function (searchHit) {
        if (searchHit.highlightResultItem != null) {
            console.log(prefix + "Highlight: \n");
            var strBuilder = ""
            for  (const [key,val]  of searchHit.highlightResultItem.highlightFields.entries()) {
                strBuilder += key + ":[";
                strBuilder += val.fragments.join(",") + "]\n";
                console.log(strBuilder);
            }
        }
        for  (const [key,val]  of searchHit.searchInnerHits.entries()) {
            console.log(prefix + "Path: " + key + "\n");
            console.log(prefix + "InnerHit: \n");
            printSearchHit(val.subSearchHits, prefix + "    ");
        }
    });
}

常见问题

相关文档