MySQL中替代Like模糊查询的函数方式

 更新时间:2023年08月31日 09:27:06   作者:Once0311  
这篇文章主要介绍了MySQL中替代Like模糊查询的函数方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mysql替代Like模糊查询的函数

通常我们模糊查询都是用like关键字

比如:

查询name中包含 '王' 字 的 

SELECT name FROM employees where name LIKE '%王%' 

查询以 '王' 字开头的name

SELECT name FROM employees where name LIKE '王%' 

查询以 '王' 字结尾的name

SELECT name FROM employees where name LIKE '%王' 

替代like的三种方式

1、使用LOCATE(substr,str)函数

SELECT name FROM employees where LOCATE('王',name)>0  // 相当于Like '%王%'(>0可省略)
SELECT name FROM employees where LOCATE('王',name)=1  // 相当于Like '王%'
SELECT name FROM employees where LOCATE('王',name)=0  // 相当于 NOT Like '%王%'

 2、使用POSITION(substr IN str)函数

SELECT name FROM employees where POSITION('王'IN name)>0 //相当于LIKE '%王%'
SELECT name FROM employees where POSITION('王'IN name)=1 //相当于LIKE '王%'
SELECT name FROM employees where POSITION('王'IN name)=0 //相当于 NOT LIKE '%王%'

3、使用INSTR(str,substr)函数 跟LOCATE(substr,str)类似 只是参数位置换了

SELECT name FROM employees where INSTR(name,'王')>0 //相当于 like '%王%' (>0可省略)
SELECT name FROM employees where INSTR(name,'王')=1 //相当于 like '王%' 
SELECT name FROM employees where INSTR(name,'王')=0 //相当于 not like '%王%' 

4、使用FIND_IN_SET(str,strlist)     注意:该字段存的必须是多个值

 比如name字段中存的是(张三,李四,王五)这种数据

SELECT name FROM employees where FIND_IN_SET('王五',name)

MySQL代替like模糊查询更高效的方法

MySQL-locate()函数

LOCATE(substr,str,pos)

返回substr字符串在str里pos(起始位置)出现的位置,没有返回0

注:pos必须大于第一次出现的位置,才能显示第二次出现的位置

直接用like查询效率较低:

SELECT id,vari_sku,prod_s_id,prod_s_sku from prod_sync_s_shopee where vari_sku LIKE '%+%';

用locate()函数的替代写法:

SELECT id,vari_sku,prod_s_id,prod_s_sku from prod_sync_s_shopee where locate('+',prod_sync_s_shopee.vari_sku) <> 0;

其他函数:

  • POSITION()
  • INSTR()
  • FIND_IN_SET()

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL分区之LIST分区详解

    MySQL分区之LIST分区详解

    mysql分区之LIST分区讲解 MySQL中的LIST分区在很多方面类似于RANGE分区,下面这篇文章主要给大家介绍了关于MySQL分区之LIST分区的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • 解决Linux下Tomcat向MySQL插入数据中文乱码问题

    解决Linux下Tomcat向MySQL插入数据中文乱码问题

    本文给大家介绍的是如何解决win平台下开发的项目移植到Linux平台后,向MySQL插入数据时中文出现乱码的问题,非常的简单实用,有需要的小伙伴可以参考下
    2018-04-04
  • MySQL 字符串模式匹配 扩展正则表达式模式匹配

    MySQL 字符串模式匹配 扩展正则表达式模式匹配

    MySQL提供标准的SQL模式匹配,以及一种基于象Unix实用程序如vi、grep和sed的扩展正则表达式模式匹配的格式。
    2010-03-03
  • 详解mysql数据去重的三种方式

    详解mysql数据去重的三种方式

    本文主要介绍了mysql数据去重的三种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • 关于MySQL表中没有主键时如何找到重复的数据

    关于MySQL表中没有主键时如何找到重复的数据

    这篇文章主要来和探讨一下关于MySQL表中没有主键时,该如何找到重复的数据,文中的示例代码讲解详细,具有一定的参考价值,需要的可以了解一下
    2023-06-06
  • MySQL修改root密码的多种方法(推荐)

    MySQL修改root密码的多种方法(推荐)

    本文给大家分享了三种方法来解决mysql修改root密码的方法,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2017-03-03
  • MySQL关闭SSL的简单方法

    MySQL关闭SSL的简单方法

    这篇文章主要介绍了MySQL关闭SSL的简单方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • MySQL 数据库聚合查询和联合查询操作

    MySQL 数据库聚合查询和联合查询操作

    这篇文章主要介绍了MySQL 数据库聚合查询和联合查询操作,需要的朋友可以参考下
    2021-12-12
  • Ubuntu中MySQL的参数文件my.cnf示例详析

    Ubuntu中MySQL的参数文件my.cnf示例详析

    这篇文章主要给大家介绍了关于Ubuntu中MySQL的参数文件my.cnf的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-10-10
  • 经典mysql连接查询例题

    经典mysql连接查询例题

    本文通过一个有趣的例子向我们介绍了mysql连接查询,采用了子查询和连接查询混合和多次连接查询,需要的朋友可以参考下
    2015-07-07

最新评论