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

相关推荐
Dxy12393102168 分钟前
Python MySQL 错误回滚实战代码
数据库·python·mysql
·云扬·1 小时前
InnoDB Cluster高可用测试实战:主从切换与故障恢复验证
数据库·mysql
oMcLin1 小时前
Ubuntu 24.04系统 防火墙配置问题导致 MySQL 无法远程连接:firewalld 与 iptables 的冲突排查
linux·mysql·ubuntu
技术不打烊2 小时前
InnoDB 核心原理拆解:缓冲池、Redo Log、MVCC 的底层逻辑
后端·mysql
Damon小智2 小时前
NiFi实现数据存储到数据库
数据库·mysql·docker·postgresql·nifi
资深web全栈开发3 小时前
Zanzibar vs MySQL Permission System - 实证性能对比研究
数据库·mysql·权限设计·zanzibar
是娇娇公主~3 小时前
快速了解MySQL索引(什么是索引,分类)
mysql
张较瘦_3 小时前
MySQL | 文本数据类型(CHAR/VARCHAR/TEXT/BLOB):区别、场景与实战
数据库·mysql
悄悄敲敲敲3 小时前
MySQL内置函数
数据库·mysql
小北方城市网3 小时前
第 5 课:后端工程化进阶 ——Python 分层架构 + 中间件 + 日志 / 异常统一处理(打造企业级高可用后端)
数据库·人工智能·python·mysql·数据库架构