您好,欢迎访问一九零五行业门户网

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

由于今天一网站的子分类用到了关于sql instr()与locate()字符串操作函数,下面做个笔记放下来,有需要的朋友可以参考一下。
instr(str,substr)
返回字符串 str 中子字符串的第一个出现位置。这和locate()的双参数形式相同,除非参数的顺序被颠倒。 
 代码如下 复制代码
> select instr('foobarbar', 'bar');
        -> 4
mysql> select instr('xbar', 'foobar');
        -> 0
locate(substr,str) , locate(substr,str,pos)
第一个语法返回字符串 str中子字符串substr的第一个出现位置。第二个语法返回字符串 str中子字符串substr的第一个出现位置, 起始位置在pos。如若substr 不在str中,则返回值为0。
 代码如下 复制代码
mysql> select locate('bar', 'foobarbar');
        -> 4
mysql> select locate('xbar', 'foobar');
        -> 0
mysql> select locate('bar', 'foobarbar',5);
        -> 7
这个函数支持多字节字元,并且只有当至少有一个参数是二进制字符串时区分大小写。
position(substr in str)
返回子串 substr 在字符串 str 中第一次出现的位置。如果子串 substr 在 str 中不存在,返回值为 0:
 代码如下 复制代码
mysql> select position('bar', ‘foobarbar');
-> 4
mysql> select position('xbar', ‘foobar');
-> 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 秒)
其它类似信息

推荐信息