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

相关推荐
<花开花落>22 分钟前
Cursor 的 MCP 应用:mysql-mcp-server
mysql·cursor·mcp
Boilermaker199230 分钟前
[MySQL] 设计范式与 E-R 图绘制
mysql·oracle·设计规范
卡尔特斯38 分钟前
MySQL 字符集与排序规则总结
mysql
luoluoal40 分钟前
基于python的RSA算法的数字签名生成软件(源码+文档)
python·mysql·django·毕业设计
@zulnger43 分钟前
Python 连接 MySQL 数据库_pymysql
数据库·python·mysql
gjc5922 小时前
MySQL 主从复制全解析:从基础原理到高级实战简介(附架构图)
数据库·mysql
kong79069282 小时前
MySQL的安装与卸载
数据库·mysql
iVictor2 小时前
MySQL 在哪些场景下不会写 binlog
mysql
minhuan2 小时前
大模型应用:与传统数据库融合:打造关系型数据库MySQL的向量检索能力.31
数据库·mysql·mysql的向量检索·向量模型应用
玩转数据库管理工具FOR DBLENS2 小时前
企业数据架构选型指南:关系型与非关系型数据库的实战抉择
数据库·测试工具·mysql·oracle·架构·nosql