在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
1、简介
|
匹配方式 | 作用 |
---|---|
%xx | 表示右匹配,右边的xx字符需要完全相等,左边可以是任意字符,也可以没有字符 |
_xx | 表示右匹配,右边的xx字符需要完全相等,左边可以是任意一个字符,必须是一个不能没有字符 |
xx% | 表示左匹配,右边的xx字符需要完全相等,右边可以是任意字符,也可以没有字符 |
xx_ | 表示左匹配,左边的xx字符需要完全相等,右边可以是任意一个字符,必须是一个不能没有字符 |
%xx% | 表示中间匹配,中间必须完全相等,左右两边可以是任意字符,左右两边可以没有其他字符 |
xx | 表示中间匹配,中间必须完全相等,左右两边可以是任意一个字符,左右两边必须是一个不能没有字符 |
首先准备一张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)
%通配符有三种匹配方式,分别是%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)
_
通配符和%
通配符的区别在于 _只匹配一个字符,并且必须匹配一个字符;而%可以匹配多个字符,甚至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)
通配符非常强大,我相信很多人都经常使用通配符,但是字符串匹配往往并不是一件性能特别快的事情。因此我们在使用通配符的时候有一些注意事项需要时刻记住。
到此这篇关于MySQL
之like
操作符详情的文章就介绍到这了,更多相关MySQL之like操作符内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界!
请发表评论