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

相关推荐
lvbinemail20 分钟前
Grafana模板自动复制图表
数据库·mysql·zabbix·grafana·监控
weixin_448119941 小时前
Datawhale Hello-Agents入门篇202512第1次作业
数据库·sql·mysql
皮皮林5511 小时前
有了开源的 MySQL,为什么还要选择 PostgreSQL?
mysql
廋到被风吹走2 小时前
【数据库】【MySQL】分库分表策略 分类、优势与短板
数据库·mysql·分类
五阿哥永琪4 小时前
MySQL 慢查询定位与 SQL 性能优化实战指南
sql·mysql·性能优化
xiaok7 小时前
GROUP BY进阶用法
mysql
李慕婉学姐7 小时前
【开题答辩过程】以《基于Android的健康助手APP的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
android·java·mysql
qq_12498707537 小时前
基于springboot健康养老APP的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·mysql·微信小程序·毕业设计
亚林瓜子8 小时前
mysql命令行手动导入csv数据到指定表
数据库·mysql·gui·csv·cli·db·import
一分半心动8 小时前
lnmp架构 mysql数据库Cannot assign requested address报错解决
linux·mysql·php