33 mysql find_in_set 的实现

前言

这里我们主要是来探讨一下 mysql 中 in 的使用, find_in_set 的使用

这两者 在我们实际应用中应该也是 非常常用的了

测试数据表如下

复制代码
CREATE TABLE `tz_test` (

  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,

  `field1` varchar(16) DEFAULT NULL,

  `field2` varchar(16) DEFAULT NULL,

  PRIMARY KEY (`id`) USING BTREE,

  KEY `field1` (`field1`) USING BTREE

) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8

然后测试数据如下

find_in_set 的实现

找主键测试一下, 可以看到 主键查询 都是使用的全表查询

因此 大概能够猜到 find_in_set 基本上都是需要全表查询的了

explain sql 如下 "select * from tz_test where FIND_IN_SET("field5", field1);"

然后我们来看下一篇 find_in_set 的是实现

sub_select 中全表遍历所有的记录, 然后这里 Item_func_find_in_set 中来进行过滤, 这里的处理类似于 in 的处理, 如果这里校验没有通过, 不响应数据给客户端

find_in_set 的具体实现如下, 就是基础的字符串处理的方式, 来判断 buffer 根据 ","号 分割之后的字符串列表 是否包含 find

相关推荐
Trouvaille ~12 分钟前
【MySQL篇】数据库操作:从创建到管理
linux·数据库·mysql·oracle·xshell·ddl
加勒比之杰克1 小时前
从阻塞 IO 到 epoll:把 Linux 网络 IO 一次讲透
linux·网络·windows·select·多路转接·epoll·poll
Chasing__Dreams1 小时前
Mysql--基础知识点--96--count * VS count 列
数据库·mysql
子木HAPPY阳VIP1 小时前
【无标题】
java·python·mysql
小糊涂灬1 小时前
Mybatis+mysql 一对多查询问题
mysql·mybatis
黑牛儿2 小时前
MySQL负载均衡配置详细步骤(新手易操作版)
mysql·adb·负载均衡
kcuwu.2 小时前
从Python\+MySQL到Redis:非关系型数据库详解(PyCharm实操版)
redis·python·mysql
工具罗某人2 小时前
docker compose 部署MySQL InnoDB Cluster + Router 高可用集群-亲测可用
mysql·docker·容器
猿小喵2 小时前
MySQL长时间未提交事务分析
数据库·mysql·性能优化
江不清丶2 小时前
深入剖析 MySQL 日志系统:Redo Log、Undo Log 与 Binlog 的协同工作原理
数据库·mysql·adb