使用弹性POST请求创建索引(将有多个记录)
POST /rewards/deals/_bulk
{ "index": {}}
{
"deal_id":25,
"title": "Deal 1 Title",
"deal_subtitle":"Deal 1 subtitle - Amazing deal 20% off",
"header_title":"Never before deal",
"header_subtitle":"This is available as an amazing deal you can use.",
"categories":[
{"categoryId":32, "categoryName":"Treats!"},
{"categoryId":31, "categoryName":"Travel & Transportation"}],
"stores_list": [{"storeId":524, "storeName":"Awesome store", "geoX":"", "geoY":"", "postalCode":"417392"}],
"merchant_name": "Merchant Name",
"id": 1,
"merchant_id": 137,
"startEnd":"2018-11-16 00:00:00",
"endDate":"2018-11-30 00:00:00"
} 编写查询以执行全文搜索。
GET /rewards/deals/_search
{
"query": {
"multi_match": {
"query": "treat",
"fields": ["title^10", "deal_subtitle^10", "header_subtitle^5", "header_title^5", "categories.categoryName^3", "stores_list.storeName^3", "stores_list.postalCode^3", "merchant_name^10"]
}
}
}但我没有得到任何数据作为回应,因为“治疗”也是categories.categoryName中提供的治疗(源于治疗)。有人能帮忙吗。当我搜索“款待”时,我会得到回应。如何才能得到以搜索关键字开头的单词的回复。
发布于 2018-11-21 08:42:19
只需在现有查询中添加"type“即可使其工作
GET /rewards/deals/_search
{
"query": {
"multi_match": {
"query": "treat",
"type":"phrase_prefix",
"fields": ["title^10", "deal_subtitle^10", "header_subtitle^5", "header_title^5", "categories.categoryName^3", "stores_list.storeName^3", "stores_list.postalCode^3", "merchant_name^10"]
}
}
}https://stackoverflow.com/questions/53398445
复制相似问题