详解MySQL like如何查询包含'%'的字段(ESCAPE用法)

 更新时间:2020年12月30日 09:57:34   作者:Mr.路痴  
这篇文章主要介绍了详解MySQL like如何查询包含'%'的字段(ESCAPE用法),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

在SQl like语句中,比如

SELECT * FROM user WHERE username LIKE '%luchi%'
SELECT * FROM user WHERE username LIKE '_luchi_',
  • % 作为通配符通配多个
  • _ 作为通配符通配一个

但当like 所要查询的字段中含有 % ,我们如何去查:

这个时候就需要指明 字段中的那个'%‘ 不作为通配符;
这里就需要用到 ESCAPE 转义

测试:

这里我们使用这张表

lchh

转义前:

SELECT * FROM user WHERE username LIKE '%%%';


这里会发现三个%号都被当做通配符了;

转义后:

SELECT * FROM user WHERE username LIKE '%1%%' ESCAPE '1';


查询成功

注:

  • ESCAPE 后面跟着一个字符,里面写着什么,什么就是转义符;
  • 然后就像 C语言中转义字符一样 例如 ‘\n','\t', 把这个字符写在你需要转义的那个%号前就可以了;

技巧与建议:

MySQL的通配符很有用。但这种功能是有代价的:通配符搜索的处理一般要比前面讨论的其他搜索所花时间更长。这里给出一些使用通配符要记住的技巧。

  • 不要过度使用通配符。如果其他操作符能达到相同的目的,应该 使用其他操作符。
  • 在确实需要使用通配符时,除非绝对有必要,否则不要把它们用 在搜索模式的开始处。把通配符置于搜索模式的开始处,搜索起 来是最慢的。
  • 仔细注意通配符的位置。如果放错地方,可能不会返回想要的数.

到此这篇关于详解MySQL like如何查询包含'%'的字段(ESCAPE用法)的文章就介绍到这了,更多相关MySQL like查询%内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 从云数据迁移服务看MySQL大表抽取模式的原理解析

    从云数据迁移服务看MySQL大表抽取模式的原理解析

    这篇文章主要介绍了从云数据迁移服务看MySQL大表抽取模式的原理解析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • MYSQL大小写不敏感导致用户登录异常问题

    MYSQL大小写不敏感导致用户登录异常问题

    这篇文章主要介绍了MYSQL大小写不敏感导致用户登录异常问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • 重装mysql时3306端口被占用的解决方法

    重装mysql时3306端口被占用的解决方法

    如果在安装mysql中出现3306端口不能使用,已经被占用的过程,则需要将该端口号的进程释放即可,所以本文给大家介绍了重装mysql时3306端口被占用的解决方法,需要的朋友可以参考下
    2024-02-02
  • mysql实现将字符串字段转为数字排序或比大小

    mysql实现将字符串字段转为数字排序或比大小

    这篇文章主要介绍了mysql实现将字符串字段转为数字排序或比大小,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • mysql 8.0.27 解压版安装配置方法图文教程

    mysql 8.0.27 解压版安装配置方法图文教程

    这篇文章主要为大家详细介绍了mysql 8.0.27 解压版安装配置方法图文教程,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • 解决MySQL报错1267 - Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci,IMPL问题

    解决MySQL报错1267 - Illegal mix of coll

    这篇文章主要给大家介绍了解决MySQL报错1267 - Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci,IMPL的问题,文中有详细的解决方案,需要的朋友可以参考下
    2023-09-09
  • MySQL如何恢复单库或单表,以及可能遇到的坑

    MySQL如何恢复单库或单表,以及可能遇到的坑

    这篇文章主要介绍了MySQL如何恢复单库或单表,以及可能遇到的坑,帮助大家更好的备份数据库,保护数据安全,感兴趣的朋友可以了解下
    2020-09-09
  • mysql 事务解析

    mysql 事务解析

    这篇文章主要给大家分享的是mysql事务解析,事务(transaction)是业务逻辑的一个基本的单元组成,下面文章围绕mysql事务的相关资料展开详细内容,需要的朋友可以参考一下希望对大家有所帮助
    2021-11-11
  • mysql如何变更自增主键id起始值

    mysql如何变更自增主键id起始值

    这篇文章主要介绍了mysql如何变更自增主键id起始值问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Mysql数据库的日志管理、备份与回复详细图文教程

    Mysql数据库的日志管理、备份与回复详细图文教程

    备份的主要目的是灾难恢复,备份还可以测试应用、回滚数据修改、查询历史数据、审计等,这篇文章主要给大家介绍了关于Mysql数据库的日志管理、备份与回复的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-08-08

最新评论