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