Elastic Search:通过单个短语查找所有记录
Elastic Search: Find All Records By Single Phrase
我正在使用 elastic-search-1.4。4.And 这是我的查询:
{
"query": {
"filtered": {
"filter": { "term": { "Name": "n" } }
}
}
}
这是我的索引文件:
{
"took" : 2,
"timed_out" : false,
"_shards" : {
"total" : 5,
"successful" : 5,
"failed" : 0
},
"hits" : {
"total" : 12,
"max_score" : 1.0,
"hits" : [ {
"_index" : "mytry",
"_type" : "users",
"_id" : "23",
"_score" : 1.0,
"_source":{"ID":23,"Name":"Abudul Rafay","Email":"a","Password":"afasd"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "28",
"_score" : 1.0,
"_source":{"ID":28,"Name":"helo","Email":"helo","Password":"heko"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "30",
"_score" : 1.0,
"_source":{"ID":30,"Name":"nup","Email":"nup","Password":"nup"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "31",
"_score" : 1.0,
"_source":{"ID":31,"Name":"apex","Email":"apex","Password":"apex"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "29",
"_score" : 1.0,
"_source":{"ID":29,"Name":"change","Email":"change","Password":"change"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "24",
"_score" : 1.0,
"_source":{"ID":24,"Name":"rafay","Email":"hello","Password":"fasfas"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "32",
"_score" : 1.0,
"_source":{"ID":32,"Name":"newtry","Email":"newtry","Password":"newtry"}
}, {
"index" : "mytry",
"_type" : "users",
"_id" : "25",
"_score" : 1.0,
"_source":{"ID":25,"Name":"r rafay ","Email":"r rafay","Password":"r rafay"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "19",
"_score" : 1.0,
"_source":{"ID":19,"Name":"n","Email":"a","Password":"a"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "26",
"_score" : 1.0,
"_source":{"ID":26,"Name":"New User","Email":"New","Password":"new"}
} ]
}
}
这是我在 运行 以上查询后的结果:
{
"took" : 2,
"timed_out" : false,
"_shards" : {
"total" : 5,
"successful" : 5,
"failed" : 0
},
"hits" : {
"total" : 1,
"max_score" : 1.0,
"hits" : [ {
"_index" : "mytry",
"_type" : "users",
"_id" : "19",
"_score" : 1.0,
"_source":{"ID":19,"Name":"n","Email":"a","Password":"a"}
} ]
}
}
所以,我想获取所有开始的或名称 Field.I 中包含单词 'n' 的记录,尝试使用聚合但它不起作用。
您可以为此使用通配符查询。术语查询将检查完全匹配。
http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/query-dsl-wildcard-query.html
我正在使用 elastic-search-1.4。4.And 这是我的查询:
{
"query": {
"filtered": {
"filter": { "term": { "Name": "n" } }
}
}
}
这是我的索引文件:
{
"took" : 2,
"timed_out" : false,
"_shards" : {
"total" : 5,
"successful" : 5,
"failed" : 0
},
"hits" : {
"total" : 12,
"max_score" : 1.0,
"hits" : [ {
"_index" : "mytry",
"_type" : "users",
"_id" : "23",
"_score" : 1.0,
"_source":{"ID":23,"Name":"Abudul Rafay","Email":"a","Password":"afasd"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "28",
"_score" : 1.0,
"_source":{"ID":28,"Name":"helo","Email":"helo","Password":"heko"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "30",
"_score" : 1.0,
"_source":{"ID":30,"Name":"nup","Email":"nup","Password":"nup"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "31",
"_score" : 1.0,
"_source":{"ID":31,"Name":"apex","Email":"apex","Password":"apex"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "29",
"_score" : 1.0,
"_source":{"ID":29,"Name":"change","Email":"change","Password":"change"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "24",
"_score" : 1.0,
"_source":{"ID":24,"Name":"rafay","Email":"hello","Password":"fasfas"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "32",
"_score" : 1.0,
"_source":{"ID":32,"Name":"newtry","Email":"newtry","Password":"newtry"}
}, {
"index" : "mytry",
"_type" : "users",
"_id" : "25",
"_score" : 1.0,
"_source":{"ID":25,"Name":"r rafay ","Email":"r rafay","Password":"r rafay"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "19",
"_score" : 1.0,
"_source":{"ID":19,"Name":"n","Email":"a","Password":"a"}
}, {
"_index" : "mytry",
"_type" : "users",
"_id" : "26",
"_score" : 1.0,
"_source":{"ID":26,"Name":"New User","Email":"New","Password":"new"}
} ]
}
}
这是我在 运行 以上查询后的结果:
{
"took" : 2,
"timed_out" : false,
"_shards" : {
"total" : 5,
"successful" : 5,
"failed" : 0
},
"hits" : {
"total" : 1,
"max_score" : 1.0,
"hits" : [ {
"_index" : "mytry",
"_type" : "users",
"_id" : "19",
"_score" : 1.0,
"_source":{"ID":19,"Name":"n","Email":"a","Password":"a"}
} ]
}
}
所以,我想获取所有开始的或名称 Field.I 中包含单词 'n' 的记录,尝试使用聚合但它不起作用。
您可以为此使用通配符查询。术语查询将检查完全匹配。
http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/query-dsl-wildcard-query.html