1.概述
原文:https://www.cnblogs.com/wjx-blog/p/12097892.html
1.1 WildCard
GET /people/_search
{
"query":{
"wildcard":{
"firstName":"japa*"
}
}
}
上面的可以使用问号和星号两个形式的查询,下面是解释:
?, which matches any single character 匹配任意个字符
*, which can match zero or more characters, including an empty one,翻译:可以匹配0个或多个字符,包含空字符
1.2 Fuzzy
GET /people/_search
{
"query":{
"fuzzy":{
"firstName":"japen"
}
}
}
japen可以匹配到japan,即使有一个字符不一样,也可以匹配出来
1.3 Regexp
假设您只想匹配以W开头,紧跟着数字的邮政编码。使用regexp查询能够让你写下更复杂的模式:备注:这个正则最好是用到不分词的字段里,如果做过分词以后就只能对分词后的词组或词进行搜索,意义就不大了。
GET /my_index/address/_search
{
"query": {
"regexp": {
"postcode": "W[0-9].+"
}
}
}
GET /person_index/_search
{
"query":{
"regexp":{
"postCode":
{
"value":"W.*"
}
}
}
}
匹配手机号:
GET /person_index/_search
{
"query":{
"regexp":{
"address":
{
"value":"1[35678][0-9]{9}"
}
}
}
}
这个正则表达式的规定了词条需要以W开头,紧跟着一个0到9的数字,然后是一个或者多个其它字符。
下面例子是所有以 wxopen 开头的正则
{
"query": {
"regexp": {
"hostname": "wxopen.*"
}
}
}
1.4 prefix
以什么字符开头的,可以更简单地用 prefix,如下面的例子
GET /_search
{
"query": {
"prefix": {
"user": {
"value": "ki"
}
}
}
}
或者
GET /_search
{
"query": {
"prefix" : { "user" : "ki" }
}
}