MySQL模糊查询使用INSTR替代LIKE

柔光的暖阳◎ 2023-06-12 09:07 142阅读 0赞

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

  1. INSTR(str,substr);

INSTR函数接受两个参数:

str 是要搜索的字符串。
substr 是要搜索的子字符串。
MySQL INSTR函数示例

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

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

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

  1. mysql> SELECT INSTR('MySQL INSTR', 'SQL');
  2. +-----------------------------+
  3. | INSTR('MySQL INSTR', 'SQL') |
  4. +-----------------------------+
  5. | 3 |
  6. +-----------------------------+
  7. 1 row in set

例2

  1. SELECT * FROM sys_user where INSTR(name, 'a' )>0

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

发表评论

表情:
评论列表 (有 0 条评论,142人围观)

还没有评论,来说两句吧...

相关阅读