MySQL模糊查询使用INSTR替代LIKE

本文介绍如何利用MySQL中的INSTR函数替代LIKE查询,提高查询效率。INSTR函数能快速定位子字符串在主字符串中的位置,若未找到则返回0。通过示例展示INSTR函数的具体应用,如查找用户名称中包含特定字符的用户。

使用内部函数INSTR,代替传统的LIKE方式查询,并且速度更快。 
INSTR()函数返回字符串中子字符串第一次出现的位置。如果在str中找不到子字符串,则INSTR()函数返回零(0)。 
下面说明了INSTR函数的语法。

INSTR(str,substr);1

INSTR函数接受两个参数:


str 是要搜索的字符串。
substr 是要搜索的子字符串。


MySQL INSTR函数示例

以下语句返回MySQL INSTR字符串中的子字符串SQL的位置。

SELECT INSTR('MySQL INSTR', 'SQL');1

执行上面查询语句,得到以下结果:

mysql> SELECT INSTR('MySQL INSTR', 'SQL');
+-----------------------------+
| INSTR('MySQL INSTR', 'SQL') |
+-----------------------------+
|                           3 |
+-----------------------------+
1 row in set1234567

例2

SELECT * FROM sys_user where INSTR(name, 'a' )>01

查找用户名称name中包含a的用户,作用类似于LIKE ‘%a%’

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值