like操作符

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: like操作符

1、简介

当对未知或者说知道某一部分的值进行过滤时,可以使用like操作符;like操作符用于模糊匹配。

like支持两个通配符,它们分别是:

  • %通配符,用于匹配多个字符
  • _通配符,用于匹配单个字符

通配符根据其所处未知又分为六种匹配方式:

匹配方式

作用

%xx

表示右匹配,右边的xx字符需要完全相等,左边可以是任意字符,也可以没有字符

_xx

表示右匹配,右边的xx字符需要完全相等,左边可以是任意一个字符,必须是一个不能没有字符

xx%

表示左匹配,右边的xx字符需要完全相等,右边可以是任意字符,也可以没有字符

xx_

表示左匹配,左边的xx字符需要完全相等,右边可以是任意一个字符,必须是一个不能没有字符

%xx%

表示中间匹配,中间必须完全相等,左右两边可以是任意字符,左右两边可以没有其他字符

_xx_

表示中间匹配,中间必须完全相等,左右两边可以是任意一个字符,左右两边必须是一个不能没有字符

2、正文

首先准备一张User表,DDL和表数据如下所示,可以直接复制使用。

SET NAMES utf8mb4;

SET FOREIGN_KEY_CHECKS = 0;


-- ----------------------------

-- Table structure for user

-- ----------------------------

DROP TABLE IF EXISTS `user`;

CREATE TABLE `user`  (

 `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',

 `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '用户名',

 `age` int(11) NOT NULL COMMENT '年龄',

 `sex` smallint(6) NOT NULL COMMENT '性别',

 PRIMARY KEY (`id`) USING BTREE

) ENGINE = InnoDB AUTO_INCREMENT = 8 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;


-- ----------------------------

-- Records of user

-- ----------------------------

INSERT INTO `user` VALUES (1, '李子捌', 18, 1);

INSERT INTO `user` VALUES (2, '张三', 22, 1);

INSERT INTO `user` VALUES (3, '李四', 38, 1);

INSERT INTO `user` VALUES (4, '王五', 25, 1);

INSERT INTO `user` VALUES (5, '六麻子', 13, 0);

INSERT INTO `user` VALUES (6, '田七', 37, 1);

INSERT INTO `user` VALUES (7, '谢礼', 18, 1);


SET FOREIGN_KEY_CHECKS = 1;

数据的初始顺序如下所示:

mysql> select * from user;

+----+--------+-----+-----+

| id | name   | age | sex |

+----+--------+-----+-----+

|  1 | 李子捌 |  18 |   1 |

|  2 | 张三   |  22 |   1 |

|  3 | 李四   |  38 |   1 |

|  4 | 王五   |  25 |   1 |

|  5 | 六麻子 |  13 |   0 |

|  6 | 田七   |  37 |   1 |

|  7 | 谢礼   |  18 |   1 |

+----+--------+-----+-----+

7 rows in set (0.00 sec)

2.1 %通配符

%通配符有三种匹配方式,分别是%xx、xx%、%xx%,接下来演示三者的简单用法。

需求:

查询user表中姓氏为张的用户

语句:

mysql> select * from user where name like '张%';

+----+------+-----+-----+

| id | name | age | sex |

+----+------+-----+-----+

|  2 | 张三 |  22 |   1 |

+----+------+-----+-----+

1 row in set (0.00 sec)

需求:

查询user表中姓名以七结尾的用户

语句:

mysql> select * from user where name like '%七';

+----+------+-----+-----+

| id | name | age | sex |

+----+------+-----+-----+

|  6 | 田七 |  37 |   1 |

+----+------+-----+-----+

1 row in set (0.00 sec)

需求:

查询user表中姓名中包含李字符的用户

语句:

mysql> select * from user where name like '%李%';

+----+--------+-----+-----+

| id | name   | age | sex |

+----+--------+-----+-----+

|  1 | 李子捌 |  18 |   1 |

|  3 | 李四   |  38 |   1 |

+----+--------+-----+-----+

2 rows in set (0.00 sec)


2.2 _通配符

_通配符和%通配符的区别在于_只匹配一个字符,并且必须匹配一个字符;而%可以匹配多个字符,甚至0个字符。

需求:

查询user表中姓氏为李,并且名字只有两个中文的用户

语句:

mysql> select * from user where name like '李_';

+----+------+-----+-----+

| id | name | age | sex |

+----+------+-----+-----+

|  3 | 李四 |  38 |   1 |

+----+------+-----+-----+

1 row in set (0.00 sec)

需求:

查询user表中名为三的用户

语句:

mysql> select * from user where name like '_三';

+----+------+-----+-----+

| id | name | age | sex |

+----+------+-----+-----+

|  2 | 张三 |  22 |   1 |

+----+------+-----+-----+

1 row in set (0.00 sec)

需求:

查询user表中姓名为三个子,并且第二个子为麻的用户

语句:

mysql> select * from user where name like '_麻_';

+----+--------+-----+-----+

| id | name   | age | sex |

+----+--------+-----+-----+

|  5 | 六麻子 |  13 |   0 |

+----+--------+-----+-----+

1 row in set (0.00 sec)

2.3 通配符使用注意事项

通配符非常强大,我相信很多人都经常使用通配符,但是字符串匹配往往并不是一件性能特别快的事情。因此我们在使用通配符的时候有一些注意事项需要时刻记住。

  • 能不用则不用的原则,不用能避免通配符带来的全部问题,所以如果其他操作符能查询出来,就不要使用like
  • 在使用通配符的地方,尽量缩小查询范围,如果有多个查询条件,应该考虑能否将通配符放置到其他过滤条件的后面
  • 特别注意通配符的选择,以及通配符的位置,可以参考六种匹配方式选择自己合适的
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
算法 前端开发 数据可视化
数据结构与算法在前端开发中的实际应用
本文将探讨数据结构与算法在前端开发中的实际应用,重点介绍在处理大规模数据、优化性能和提升用户体验方面的具体场景和解决方案。
362 15
|
存储 Java 应用服务中间件
|
关系型数据库 MySQL Linux
挂载并初始化Linux数据盘,完成MySQL数据迁移
挂载并初始化Linux数据盘,完成MySQL数据迁移
1084 0
挂载并初始化Linux数据盘,完成MySQL数据迁移
|
JavaScript Java 应用服务中间件
开发者学堂课程干货总结——Java 虚拟机原理(六)
Java 虚拟机原理课时1.6——Dragonwell特性:Wisp。通过本节课的学习,能够掌握Java 虚拟机原理,学习JNI、类加载器原理、safepoint机制等知识。 电子书+视频为同学带来最佳学习效果,文字、课程链接、图谱地址统统为大家放送了哦!
开发者学堂课程干货总结——Java 虚拟机原理(六)
|
8天前
|
机器人 API 调度
基于 DMS Dify+Notebook+Airflow 实现 Agent 的一站式开发
本文提出“DMS Dify + Notebook + Airflow”三位一体架构,解决 Dify 在代码执行与定时调度上的局限。通过 Notebook 扩展 Python 环境,Airflow实现任务调度,构建可扩展、可运维的企业级智能 Agent 系统,提升大模型应用的工程化能力。
|
人工智能 前端开发 API
前端接入通义千问(Qwen)API:5 分钟实现你的 AI 问答助手
本文介绍如何在5分钟内通过前端接入通义千问(Qwen)API,快速打造一个AI问答助手。涵盖API配置、界面设计、流式响应、历史管理、错误重试等核心功能,并提供安全与性能优化建议,助你轻松集成智能对话能力到前端应用中。
657 154