sql instr()与LOCATE()字符串查找函数

SEO研究中心 SEO研究中心提供免费SEO公开课

由于今天一网站的子分类用到了关于sql instr()与LOCATE()字符串操作函数,下面做个笔记放下来,有需要的朋友可以参考一下.

INSTR(str,substr):返回字符串 str 中子字符串的第一个出现位置,这和LOCATE()的双参数形式相同,除非参数的顺序被颠倒,代码如下:

  1. mysql>SELECTINSTR('foobarbar','bar');
  2. ->4
  3. mysql>SELECTINSTR('xbar','foobar');
  4. ->0

LOCATE(substr,str),LOCATE(substr,str,pos).

第一个语法返回字符串 str中子字符串substr的第一个出现位置,第二个语法返回字符串 str中子字符串substr的第一个出现位置,起始位置在pos,如若substr 不在str中,则返回值为0,代码如下:

  1. mysql>SELECTLOCATE('bar','foobarbar');
  2. ->4
  3. mysql>SELECTLOCATE('xbar','foobar');
  4. ->0
  5. mysql>SELECTLOCATE('bar','foobarbar',5);
  6. ->7

这个函数支持多字节字元,并且只有当至少有一个参数是二进制字符串时区分大小写.

POSITION(substr IN str):返回子串 substr 在字符串 str 中第一次出现的位置,如果子串 substr 在 str 中不存在,返回值为 0,代码如下:

  1. mysql>SELECTPOSITION('bar',‘foobarbar');
  2. ->4
  3. mysql>SELECTPOSITION('xbar',‘foobar');
  4. ->0

效率测试,代码如下:

SELECT * FROM `o_soft` WHERE LOCATE('d200',tid2)>0

MySQL 返回的查询结果为空(即零行),(查询花费 0.0050 秒),代码如下:

SELECT * FROM `o_soft` WHERE INSTR('d200',tid2)>0

MySQL 返回的查询结果为空(即零行),(查询花费 0.0009 秒).

相关广告
  • sql instr()与LOCATE()字符串查找函数 sql instr()与LOCATE()字符串查找函数 sql instr()与LOCATE()字符串查找函数
相关阅读

sql instr()与LOCATE()字符串查找函数

2019/10/10 17:33:07 | 谷歌SEO算法 | DNS