9. 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 table_name WHERE column_name REGEXP 'pattern';

示例

复制代码
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]+$';

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

参考资料

相关推荐
极限实验室5 分钟前
INFINI Labs 产品更新 | INFINI Console 1.29.6 发布 – 优化监控图表异常毛刺等
数据库·产品
先睡8 分钟前
优化MySQL查询
数据库·sql
小张是铁粉25 分钟前
oracle的内存架构学习
数据库·学习·oracle·架构
专注API从业者29 分钟前
构建淘宝评论监控系统:API 接口开发与实时数据采集教程
大数据·前端·数据库·oracle
藏在歌词里32 分钟前
数据库-元数据表
数据库
小乌龟不会飞2 小时前
Ubuntu 安装 etcd 与 etcd-cpp-apiv3
数据库·etcd
程序员岳焱9 小时前
Java 与 MySQL 性能优化:Java 实现百万数据分批次插入的最佳实践
后端·mysql·性能优化
计算机毕设定制辅导-无忧学长9 小时前
西门子 PLC 与 Modbus 集成:S7-1500 RTU/TCP 配置指南(一)
服务器·数据库·tcp/ip
程序员柳10 小时前
基于微信小程序的校园二手交易平台、微信小程序校园二手商城源代码+数据库+使用说明,layui+微信小程序+Spring Boot
数据库·微信小程序·layui
梦在深巷、10 小时前
MySQL/MariaDB数据库主从复制之基于二进制日志的方式
linux·数据库·mysql·mariadb