es 部分匹配 (二) - 通配符(wildcard)及正则表达式查询(regexp)

wildcard查询和prefix查询类似,也是一个基于词条的低级别查询。但是它能够让你指定一个模式(Pattern),而不是一个前缀(Prefix)。它使用标准的shell通配符:?用来匹配任意字符,*用来匹配零个或者多个字符

 

 

 

第一步:通配符查询

GET /my_index1/address/_search

{

"query": {

"wildcard": {

"postcode": "W?F*HW"

}

}

}

 

 

 

第二步:正则表达式查询

GET /my_index1/address/_search

{

"query": {

"regexp": {

"postcode": "W[0-9].+"

}

}

}

这个正则表达式的规定了词条需要以W开头,紧跟着一个0到9的数字,然后是一个或者多个其它字符。

 

SQL中的正则表达式匹配可以使用通配符Wildcard)和正则表达式函数来实现。 1. 通配符Wildcard): - `%`:代表任意字符(包括零个或多个字符) - `_`:代表任意一个字符 例如,要匹配以 "abc" 开头的任意字符串,可以使用 `LIKE` 操作符: ```sql SELECT * FROM table_name WHERE column_name LIKE 'abc%'; ``` 要匹配以 "abc" 结尾的任意字符串,可以使用: ```sql SELECT * FROM table_name WHERE column_name LIKE '%abc'; ``` 要匹配包含 "abc" 的任意位置的字符串,可以使用: ```sql SELECT * FROM table_name WHERE column_name LIKE '%abc%'; ``` 2. 正则表达式函数: 如果你的数据库支持正则表达式函数,你可以使用以下函数进行正则匹配。 - MySQL:`REGEXP` 或 `RLIKE` - PostgreSQL:`~` 或 `~*` - Oracle:`REGEXP_LIKE` - SQL Server:`LIKE` 或 `PATINDEX` 或 `SQL Server CLR` 例如,在MySQL中,要匹配以 "abc" 开头的任意字符串,可以使用 `REGEXP`: ```sql SELECT * FROM table_name WHERE column_name REGEXP '^abc'; ``` 要匹配以 "abc" 结尾的任意字符串,可以使用: ```sql SELECT * FROM table_name WHERE column_name REGEXP 'abc$'; ``` 要匹配包含 "abc" 的任意位置的字符串,可以使用: ```sql SELECT * FROM table_name WHERE column_name REGEXP 'abc'; ``` 请注意,具体的语法和支持的正则表达式功能可能因不同的数据库而异。在实际使用中,请参考你使用的数据库文档以获取更多详细信息。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值