学习几天的elasticsearch总结下match匹配以方便温习。
首先我创建了一个index:mytest,type:usertest,并插入了5条数据。
ps:用的sense浏览器插件(如何安装可以百度)
pretty:美化查询结果。
_search:搜索关键字query: 及表示查询
match: 匹配
一、简单的全查找:
式例:
POST /mytest/usertest/_search?pretty{
"query":{
"match_all": {}
}
}
mytest:index名称(对应关系数据库名称)
usertest:_type名称(对应关系数据库表名)
查询结果图:
通过hits 内total:5可以看出5条记录都查询出来了
另外一种简单的写法示例:
POST /mytest/user/_search
推荐用第一种json体的方法,扩展性和灵活性更加多样化。但是简单的查询第一种就可以完成,视情况而定吧。
这个美化查询结果,看了半天觉得没啥变化,注:_source参数不会被美化。
二、查询单条数据
1:POST /mytest/usertest/_search?q=name:xiaofang
2:json体:
POST /mytest/usertest/_search?pretty
{
"query":{
"match":{
"name":"xiaofang"
}
}
}
按照等分高低排列
笔者在使用java api进行操作时没有用QueryBuilders.matchPhraseQuery方法时返回结果包含“xiao”单词的文档(测试时使用的中文检索)
三、简单的条件查询:
查询usertest中年龄在20周岁以下的人员
1: POST /mytest/usertest/_search
{
"query": {
"match_all": {}
},
"filter":{
"range": {
"userage": {
"from": 18,
"to": 20
}
}
}
}
查询年龄小于20周岁以下的人员
2: POST /mytest/usertest/_search
{
"query": {
"match_all": {}
},
"filter":{
"range": {
"userage": {
"lt" : "20"
}
}
}
}
我们可以通过查询结果看出两者之间的差别
这两个示例用到了“filter”,“range”这两个关键词。
filter:过滤器。用于过滤我们的查询结果,让查询结果更加精确化。
range:区间。(以上是range的简单的两种写法)
"lt" 转移字符 “小于”的意思。
"gt" :“大于”的意思。
四、match_phrase关键字查询:
match_phrase:短语搜索。
对比示例:
未使用match_phrase查询的代码及结果:
POST /mytest/usertest/_search
{
"query": {
"match": {
"about": "listen music"
}
}
}
使用match_phrase查询的代码及结果:
POST /mytest/usertest/_search
{
"query": {
"match_phrase": {
"about": "listen music"
}
}
}
match_phrase查询就不多说啦,一看就明白。
五、match_phrase_prefix查询
match_phrase_prefix:匹配短语前缀查询。
上两个示例就一目了然啦:
POST /mytest/usertest/_search
{ "query": {
"match_phrase": {
"about": "love lis"
}
}
}
POST /mytest/usertest/_search
{ "query": {
"match_phrase_prefix": {
"about": "love lis"
}
}
}
关于match匹配搜索就写到这儿吧。