类似于TermQuery,但是TermsQuery可以指定多个查询关键词,查询匹配这些词的数据。多个查询关键词中只要有一个词精确匹配,该行数据就会被返回,等价于SQL中的In。
前提条件
参数
参数 | 说明 |
---|---|
TableName | 数据表名称。 |
IndexName | 多元索引名称。 |
Query | 设置查询类型为TermsQuery。 |
FieldName | 要匹配的字段。 |
Terms | 多个查询关键词,即要匹配的值。 多个查询关键词中只要有一个词精确匹配,该行数据就会被返回。 |
Limit | 本次查询需要返回的最大数量。 如果只为了获取行数,无需获取具体数据,可以设置Limit=0,即不返回任意一行数据。 |
ColumnsToGet | 是否返回所有列,包含ReturnAll和Columns设置。 ReturnAll默认为false,表示不返回所有列,此时可以通过Columns指定返回的列;如果未通过Columns指定返回的列,则只返回主键列。 当设置ReturnAll为true时,表示返回所有列。 |
示例
/**
* 查询表中Col_Keyword列精确匹配"hangzhou"或"tablestore"的数据。
*/
func TermsQuery(client *tablestore.TableStoreClient, tableName string, indexName string) {
searchRequest := &tablestore.SearchRequest{}
searchRequest.SetTableName(tableName)
searchRequest.SetIndexName(indexName)
query := &search.TermsQuery{} //设置查询类型为TermsQuery。
query.FieldName = "Col_Keyword" //设置要匹配的字段。
terms := make([]interface{}, 0)
terms = append(terms, "hangzhou")
terms = append(terms, "tablestore")
query.Terms = terms //设置要匹配的值。
searchQuery := search.NewSearchQuery()
searchQuery.SetQuery(query)
searchQuery.SetLimit(100)
searchRequest.SetSearchQuery(searchQuery)
//设置为返回所有列。
searchRequest.SetColumnsToGet(&tablestore.ColumnsToGet{
ReturnAll: true,
})
searchResponse, err := client.Search(searchRequest)
if err != nil {
fmt.Printf("%#v", err)
return
}
fmt.Println("IsAllSuccess: ", searchResponse.IsAllSuccess) //查看返回结果是否完整。
fmt.Println("RowCount: ", len(searchResponse.Rows))
for _, row := range searchResponse.Rows {
jsonBody, err := json.Marshal(row)
if err != nil {
panic(err)
}
fmt.Println("Row: ", string(jsonBody))
}
}