MySQL字符串函数:locate()使用方法详解

定义

LOCATE - 查找一个子串在另外一个字符串是否存在mysql

语法

LOCATE(substr,str[,pos])

网上各类文章都说有两种语法,其实只不过第三个参数可选,且默认为1而已,何须搞这么复杂。
翻看了一下手册,12.7小节里确实也是两种,不知道为何。sql

返回 substr 在 str 从 pos 开始第一次出现的位置,索引从1开始,不存在则返回0.
有别于PHP函数,strpos,是从0开始,参数顺序也不一致。函数

经常使用于where条件中,由于存在则返回大于0的值,不存在返回0,不用考虑存在而返回0的状况(PHP中strpos是须要的),反而比较简单,示例以下url

示例

update site set url =concat('http://',url) where locate('http://',url)=0;
mysql> SELECT LOCATE('bar', 'foobarbar');
        -> 4
mysql> SELECT LOCATE('xbar', 'foobar');
        -> 0
mysql> SELECT LOCATE('bar', 'foobarbar', 5);
        -> 7
相关文章
相关标签/搜索