MySQL函数Locate的使用详解

 更新时间:2022年08月15日 09:34:05   作者:今夜无风亦无雨  
本文主要介绍了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实现的功能是一样的。

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

示例

SELECT * 
FROM party_course_study
WHERE LOCATE(findCode, '00001') >0
 
// 注:Mybatis使用场景,需要加 <![CDATA[ ]]>
SELECT * 
FROM party_course_study
WHERE <![CDATA[ LOCATE(findCode, '00001') > 0 ]]>

功能类似的函数(不做详细介绍)

  • LOCATE(substr,str) ,
  • LOCATE(substr,str,pos)
  • POSITION(substr IN str)
  • INSTR(str,substr)

 到此这篇关于MySQL函数Locate的使用详解的文章就介绍到这了,更多相关MySQL Locate函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

最新评论