Mysql 模糊查询和正则表达式实例详解

 更新时间:2023年11月25日 11:09:35   作者:有请小发菜  
在MySQL中,可以使用LIKE运算符进行模糊查询,LIKE运算符用于匹配字符串模式,其中可以使用通配符来表示任意字符或字符序列,这篇文章主要介绍了Mysql 模糊查询和正则表达式实例详解,需要的朋友可以参考下

一、模糊查询

1.1 LIKE运算符

在MySQL中,可以使用LIKE运算符进行模糊查询。LIKE运算符用于匹配字符串模式,其中可以使用通配符来表示任意字符或字符序列。

示例代码

SELECT * FROM table_name WHERE column_name LIKE 'pattern';
  • table_name:要查询的表名
  • column_name:要查询的列名
  • pattern:要匹配的模式

通配符

  • %:表示任意字符序列(包括空字符)
  • _:表示任意单个字符

示例

SELECT * FROM users WHERE name LIKE '%John%';

以上示例将返回所有名字中包含"John"的用户。

1.2 NOT LIKE运算符

NOT LIKE运算符用于排除符合指定模式的结果。

示例代码

SELECT * FROM table_name WHERE column_name NOT LIKE 'pattern';

示例

SELECT * FROM users WHERE name NOT LIKE '%John%';

以上示例将返回所有名字中不包含"John"的用户。

1.3 REGEXP运算符

REGEXP运算符用于基于正则表达式进行模糊查询。正则表达式是一种强大的模式匹配工具,可以用于更复杂的模式匹配。

示例代码

SELECT * FROM users WHERE name NOT LIKE '%John%';

示例

SELECT * FROM users WHERE name REGEXP '[Jj]ohn';

以上示例将返回所有名字中包含以"J"或"j"开头,后面跟着"ohn"的用户。

二、正则表达式

2.1 正则表达式基础

正则表达式是一种用于匹配字符串模式的工具。它使用一种特定的语法来描述要匹配的模式。

  • .:匹配任意字符
  • ^:匹配字符串的开始位置
  • $:匹配字符串的结束位置
  • []:匹配指定字符集中的任意一个字符
  • [^]:匹配任意不在指定字符集中的字符
  • *:匹配前面的元素零次或多次
  • +:匹配前面的元素一次或多次
  • ?:匹配前面的元素零次或一次
  • |:匹配两个或多个表达式中的任意一个
SELECT * FROM table_name WHERE column_name REGEXP 'pattern';

2.2 REGEXP运算符

在MySQL中,可以使用REGEXP运算符基于正则表达式进行模糊查询。

示例代码

SELECT * FROM table_name WHERE column_name REGEXP 'pattern';

示例

SELECT * FROM users WHERE name REGEXP '^[A-Za-z]+$';

以上示例将返回所有名字只包含字母的用户。

2.3 RLIKE运算符

RLIKE运算符是REGEXP运算符的同义词,可以使用RLIKE代替REGEXP进行正则表达式匹配。

示例代码

SELECT * FROM table_name WHERE column_name RLIKE 'pattern';

示例

SELECT * FROM users WHERE name RLIKE '^[A-Za-z]+$';

以上示例将返回所有名字只包含字母的用户。

参考资料

MySQL官方文档:Pattern Matching

MySQL官方文档:Regular Expressions

到此这篇关于Mysql 模糊查询和正则表达式的文章就介绍到这了,更多相关Mysql 模糊查询正则表达式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mysql锁机制之行锁、表锁、死锁的实现

    Mysql锁机制之行锁、表锁、死锁的实现

    本文主要介绍了Mysql锁机制之行锁、表锁、死锁的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • mysql手动删除BINLOG的方法

    mysql手动删除BINLOG的方法

    用于删除列于在指定的日志或日期之前的日志索引中的所有二进制日志。这些日志也会从记录在日志索引文件
    2013-03-03
  • MySql8.0以上版本正确修改ROOT密码的方法

    MySql8.0以上版本正确修改ROOT密码的方法

    这篇文章主要介绍了MySql8.0以上版本正确修改ROOT密码的方法,文中给大家提到了成功部署完毕后出现故障情况,本文分步骤给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-06-06
  • mysql8.0及以上my.cnf设置lower_case_table_names=1无法启动问题

    mysql8.0及以上my.cnf设置lower_case_table_names=1无法启动问题

    这篇文章主要介绍了mysql8.0及以上my.cnf设置lower_case_table_names=1无法启动问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • mysql中update和select结合使用方式

    mysql中update和select结合使用方式

    这篇文章主要介绍了mysql中update和select结合使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • MySQL中USING 和 HAVING 用法实例简析

    MySQL中USING 和 HAVING 用法实例简析

    这篇文章主要介绍了MySQL中USING 和 HAVING 用法,结合实例形式简单分析了mysql中USING 和 HAVING的功能、使用方法及相关操作注意事项,需要的朋友可以参考下
    2019-08-08
  • 傻瓜式用Eclipse连接MySQL数据库

    傻瓜式用Eclipse连接MySQL数据库

    本来不想写这么简单人文章,在百度上搜索我这个标题,完全符合标题的一大堆。但我按照那些文章捣鼓了很久,就是不行。
    2015-09-09
  • 配置mysql允许远程连接的方法

    配置mysql允许远程连接的方法

    默认情况下,MySQL只允许本地登录,如果要开启远程连接,则需要修改/etc/my.cnf文件
    2013-02-02
  • MySQL8.0升级的踩坑历险记

    MySQL8.0升级的踩坑历险记

    听说mysql8的性能提升了很多,对于我这种喜欢把所有软件升级到最新版的人来说,二话不说直接升级,这篇文章主要给大家介绍了关于MySQL8.0升级踩坑的相关资料,需要的朋友可以参考下
    2021-10-10
  • 用logrotate归档MySQL日志的实现

    用logrotate归档MySQL日志的实现

    本文介绍了使用logrotate工具对MySQL日志进行自动归档和管理,通过配置logrotate,可以实现按周归档,文件大于2G时执行,保留最近两周的数据,感兴趣的可以了解一下
    2025-09-09

最新评论