加载中...

MySQL函数Locate的使用

MySQL函数Locate的使用

Locate函数主要的作用是判断一个字符串是否包含另一个字符串,如

Locate(str,sub) > 0,表示sub字符串包含str字符串;

Locate(str,sub) = 0,表示sub字符串不包含str字符串。

该函数常常与<![CDATA[]]> 组件一起使用,该组件作用是防止字符串进行转义。比如:

select * from stu s where <![CDATA[Locate(#{name},s.name)>0]]>

mysql的instr函数有着相似的功能,instr(str,sub)返回的是字符串sub在字符串str第一次出现的位置,其中instr(str,sub) = 0 表示字符串str不包含字符串sub。

因此,locate,instr,like都可以用来实现模糊查询,如下三条sql实现的功能是一样的。

  1. select * from stu s where s.name like concat(''%'',#{name},''%'') ;
  2. select * from stu s where instr(s.name,#{name}) > 0;
  3. select * from stu s where locate(#{name},s.name) > 0;